:root{--bg: #F7F9F9;--surface: #ffffff;--ink: #0f172a;--muted: #313c4d;--line: #e6e8ee;--brand: #0A8059;--brand-600: #065f46;--brand-100: #DFF7E5;--brand-soft: #DFF7E5;--accent: #4CAF50;--accent-soft: #DFF7E5;--warm: #f59e0b;--warm-soft: #fffbeb;--radius-lg: 20px;--radius-md: 16px;--radius-sm: 10px;--shadow-1: 0 2px 6px rgba(2,6,23,.06);--shadow-2: 0 8px 24px rgba(2,6,23,.08);--shadow-3: 0 18px 48px rgba(2,6,23,.1);--spacing: 20px}.dash{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--ink);background:#fff;min-height:100vh;display:flex;width:100%}.dash-main{background:#fff;flex:1;margin-left:260px;min-height:100vh;width:calc(100% - 260px);overflow-x:hidden;transition:margin-left .3s ease,width .3s ease}.dash-main.sidebar-collapsed{margin-left:80px;width:calc(100% - 80px)}.dash .dash-wrap{max-width:1200px;margin:0 auto;padding:40px 50px 56px;width:100%;box-sizing:border-box}.dash-sidebar{width:260px;min-width:260px;background:#f8fafc;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;z-index:10;overflow-y:auto;transition:width .3s ease,min-width .3s ease}.dash-sidebar.collapsed{width:80px;min-width:80px}.dash-sidebar.collapsed .sidebar-brand-text,.dash-sidebar.collapsed .nav-item span:not(.nav-badge),.dash-sidebar.collapsed .nav-badge{opacity:0;width:0;overflow:hidden}.dash-sidebar.collapsed .nav-item{justify-content:center;padding:12px}.dash-sidebar.collapsed .sidebar-brand{justify-content:center;padding:24px 12px}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid #e2e8f0;background:#fff}.sidebar-logo{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff8c00,#ff6b00);color:#fff;border-radius:10px;width:36px;height:36px;box-shadow:0 4px 12px #ff8c0040;flex-shrink:0}.sidebar-brand-text{font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:16px;background:linear-gradient(135deg,var(--brand) 0%,#065f46 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:var(--muted);text-decoration:none;font-weight:500;font-size:15px;position:relative;transition:background .2s ease,color .2s ease}.nav-item svg{flex-shrink:0;opacity:.7}.nav-item:hover{background:var(--brand-soft);color:var(--brand-600);border:none}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--brand-soft);color:var(--brand-600);font-weight:600}.nav-item.active svg{opacity:1}.nav-badge{margin-left:auto;background:var(--brand);color:#fff;padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px}.nav-item-signout{color:#dc2626}.nav-item-signout:hover{background:#fef2f2;color:#dc2626}.sidebar-footer{padding:16px 12px;border-top:1px solid #e2e8f0;background:#fff}.sidebar-toggle{position:absolute;top:50%;right:-12px;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20;color:var(--muted);transition:background .2s ease,color .2s ease}.sidebar-toggle:hover{background:var(--brand-soft);color:var(--brand-600);border-color:var(--brand-100)}.dash-welcome{padding:20px 36px;text-align:center;border-radius:var(--radius-lg);position:relative;overflow:hidden}.dash-welcome:before{content:"";position:absolute;top:-30%;right:-5%;width:300px;height:300px;background:radial-gradient(circle,rgba(10,128,89,.08) 0%,transparent 70%);border-radius:50%}.dash .dash-title{font-size:30px;font-weight:800;margin:0 0 12px;letter-spacing:-.03em;color:var(--ink);position:relative;z-index:1}.dash .dash-sub{max-width:600px;margin:0 auto;color:var(--muted);font-size:18px;font-style:italic;font-weight:400;line-height:1.7;position:relative;z-index:1}.dash .btn-link,.dash .btn-outline{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;color:var(--ink);border:1px solid #e2e8f0;text-decoration:none;cursor:pointer;font-size:14px;transition:background .2s ease,border-color .2s ease}.dash .btn-outline{padding:10px 14px}.dash .btn-link:hover,.dash .btn-outline:hover{background:#f8fafc;border-color:#dde3ea}.dash .btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;cursor:pointer;background:var(--brand);color:#fff;border:none;font-weight:600;font-size:14px;transition:background .2s ease}.dash .btn-primary.small{padding:8px 14px;font-size:13px}.dash .btn-primary:hover{background:var(--brand-600)}.dash .btn-primary:active{background:#065f46}.dash .badge{background:var(--brand-soft);color:var(--brand-600);padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px}.dash .muted-link{color:var(--muted);text-decoration:none;font-weight:500;font-size:14px;transition:color .2s ease}.dash .muted-link:hover{color:var(--brand)}.dash .i{display:inline-flex;width:24px;height:24px;background:var(--brand);border-radius:8px;flex-shrink:0;margin-right:8px}.dash .i-pen{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4 12.5-12.5z'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 20h9'/%3E%3Cpath d='M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4 12.5-12.5z'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .i-book{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 12c2.209 0 4-1.791 4-4s-1.791-4-4-4-4 1.791-4 4 1.791 4 4 4z'/%3E%3Cpath d='M4 20c0-2.761 3.582-5 8-5s8 2.239 8 5'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 12c2.209 0 4-1.791 4-4s-1.791-4-4-4-4 1.791-4 4 1.791 4 4 4z'/%3E%3Cpath d='M4 20c0-2.761 3.582-5 8-5s8 2.239 8 5'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .i-calendar{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .card{background:#fff;border-radius:var(--radius-lg);padding:20px;margin-bottom:30px;border:1px solid #e2e8f0;box-shadow:var(--shadow-1);position:relative}.dash .card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.dash .card-title{font-weight:700;font-size:19px;display:flex;align-items:center;gap:12px;letter-spacing:-.02em;color:var(--ink)}.dash .stats-grid{margin-bottom:32px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}@media(max-width:980px){.dash .stats-grid{grid-template-columns:repeat(2,minmax(140px,1fr))!important}}.dash .stat{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:16px;padding:15px;box-shadow:var(--shadow-1);position:relative;transition:box-shadow .2s ease,border-color .2s ease}.dash .stat:before{content:"";display:none}.dash .stat-icon{display:inline-flex;width:24px;height:24px;background:var(--brand);border-radius:6px;flex-shrink:0}.dash .stat-icon-trend{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='23 6 13.5 15.5 8.5 10.5 1 18'/%3E%3Cpolyline points='17 6 23 6 23 12'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='23 6 13.5 15.5 8.5 10.5 1 18'/%3E%3Cpolyline points='17 6 23 6 23 12'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .stat-icon-clock{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpolyline points='12 6 12 12 16 14'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .stat-icon-star{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}.dash .stat-icon-trophy{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9H4.5a2.5 2.5 0 0 1 0-5H6'/%3E%3Cpath d='M18 9h1.5a2.5 2.5 0 0 0 0-5H18'/%3E%3Cpath d='M4 22h16'/%3E%3Cpath d='M10 14.66V17c0 .55-.47.98-.97 1.21C7.85 18.75 7 20.24 7 22'/%3E%3Cpath d='M14 14.66V17c0 .55.47.98.97 1.21C16.15 18.75 17 20.24 17 22'/%3E%3Cpath d='M18 2H6v7a6 6 0 0 0 12 0V2Z'/%3E%3C/svg%3E");mask-size:16px 16px;mask-repeat:no-repeat;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9H4.5a2.5 2.5 0 0 1 0-5H6'/%3E%3Cpath d='M18 9h1.5a2.5 2.5 0 0 0 0-5H18'/%3E%3Cpath d='M4 22h16'/%3E%3Cpath d='M10 14.66V17c0 .55-.47.98-.97 1.21C7.85 18.75 7 20.24 7 22'/%3E%3Cpath d='M14 14.66V17c0 .55.47.98.97 1.21C16.15 18.75 17 20.24 17 22'/%3E%3Cpath d='M18 2H6v7a6 6 0 0 0 12 0V2Z'/%3E%3C/svg%3E");-webkit-mask-size:16px 16px;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center}@media(max-width:720px){.dash .btn-log-today{min-width:36px;padding:0;width:36px}.dash .btn-log-today .btn-text{display:none}.dash .btn-log-today .btn-icon-only{display:inline;font-size:20px;line-height:1}}.dash .stat-warm{background:var(--warm-soft);border-color:#fde68a}.dash .stat-warm:before{background:var(--warm)}.dash .stat:hover{box-shadow:0 4px 12px #00000014;border-color:var(--brand-100)}.dash .stat-ttl{font-weight:600;font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.dash .score{display:flex;align-items:baseline;gap:6px;margin-bottom:12px}.dash .big{font-size:25px;font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1}.dash .of{color:var(--muted);font-weight:600;font-size:16px}.dash .bar{height:8px;background:#e2e8f0;border-radius:999px;margin:14px 0 10px;overflow:hidden}.dash .bar-fill{height:100%;background:linear-gradient(90deg,var(--brand) 0%,var(--accent) 100%);border-radius:999px}.dash .streak{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}.dash .stat .muted{font-size:13px;line-height:1.5;margin-top:6px;color:var(--muted)}.streak-section-content{display:flex;flex-direction:column;gap:12px;max-height:200px;overflow:visible}.streak-number{text-align:center;padding:4px 0;flex-shrink:0}.streak-number .big{font-size:32px!important;margin-bottom:4px!important;line-height:1.2}.streak-number .muted{font-size:13px!important}.streak-timeline{margin-top:0;flex:1;min-height:0;display:flex;flex-direction:column;overflow:visible;font-size:15px}.timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:6px;flex-shrink:0}.timeline-period{font-size:11px;font-weight:600;color:var(--ink);flex:1;text-align:center}.timeline-nav-btn{width:18px;height:18px;border-radius:4px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all .2s ease;padding:0;flex-shrink:0}.timeline-nav-btn svg{width:10px;height:10px}.timeline-nav-btn:hover:not(:disabled){background:var(--brand-soft);border-color:var(--brand);color:var(--brand-600)}.timeline-nav-btn:disabled{opacity:.4;cursor:not-allowed}.timeline-bars{display:flex;align-items:flex-end;gap:4px;height:48px;margin-bottom:6px;padding:4px 0;flex:1;min-height:0}.timeline-day{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px;height:44px;cursor:default}@media(max-width:720px){.timeline-day{height:45px}}.timeline-day-date{font-size:9px;color:var(--muted)}.timeline-day-icon{width:26px;height:26px;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;box-sizing:border-box;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;color:var(--brand)}.timeline-day.has-entry .timeline-day-icon{background:#ecfdf5;border-color:var(--brand-200)}.timeline-day.is-today .timeline-day-icon{border:2px solid var(--warm);box-shadow:0 0 0 1px #f59e0b33}.timeline-day.has-entry.is-today .timeline-day-icon{background:#ecfdf5;border-color:var(--warm)}.timeline-legend{display:flex;gap:12px;justify-content:center;font-size:9px;color:var(--muted);flex-shrink:0;margin-top:2px}.timeline-legend .legend-item{display:flex;align-items:center;gap:4px}.legend-bar{width:20px;height:20px;border-radius:999px;border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;font-size:14px}.legend-bar.has-entry{background:#ecfdf5;border-color:var(--brand-200)}.legend-bar.is-today{background:#f1f5f9;border:2px solid #fbbf24;box-shadow:0 0 0 1px #f59e0b33}@media(max-width:720px){.streak-timeline{font-size:13px;gap:6px}.timeline-header{margin-bottom:4px}.timeline-bars{gap:3px;height:45px;overflow-x:auto;padding-bottom:4px}.timeline-day{min-width:18px;height:45px;font-size:14px}.timeline-legend{font-size:10px;gap:8px}.legend-bar{width:16px;height:16px;font-size:12px}}.dash .lesson-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.dash .lesson-card{border-radius:16px;color:var(--ink);background:#fff;cursor:pointer;padding:28px;text-align:left;position:relative;box-shadow:var(--shadow-1);transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.dash .lesson-card:hover{border-color:inherit;background:#fff;box-shadow:var(--shadow-1)}.dash .lesson-icn{font-size:32px;margin-bottom:12px;display:flex;align-items:center;justify-content:center;color:var(--brand)}.dash .lesson-icn svg{width:32px;height:32px}.dash .lesson-card-solo{background:#d1fae5;border-left:4px solid #047857}.dash .lesson-card-solo .lesson-icn{color:#047857}.dash .lesson-card-partner{background:#ffedd5;border-left:4px solid #ea580c}.dash .lesson-card-partner .lesson-icn{color:#ea580c}.dash .lesson-card-group{background:#fee2e2;border-left:4px solid #b91c1c}.dash .lesson-card-group .lesson-icn{color:#b91c1c}.dash .lesson-ttl{font-weight:700;font-size:17px;margin-bottom:6px;letter-spacing:-.01em;color:var(--ink)}.dash .lesson-sub{color:var(--muted);font-size:14px;line-height:1.5}.dash .act-grid{display:grid;gap:16px;grid-template-columns:1.2fr 1fr}.dash .muted{color:var(--muted)}.dash .up-card{margin-top:12px;border:1.5px solid #e2e8f0;background:#f0fdf4;border-radius:14px;padding:20px;box-shadow:var(--shadow-1);position:relative;border-left:3px solid var(--brand);transition:box-shadow .2s ease,border-color .2s ease}.dash .up-card:hover{box-shadow:var(--shadow-1);border-color:#e2e8f0}.dash .up-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.dash .up-date{font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--ink)}.dash .up-time{font-weight:600;color:var(--brand);font-size:14px}.dash .up-with{margin:10px 0 6px;color:var(--muted);font-size:13px}.dash .tag{background:var(--brand-soft);color:var(--brand-600);padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;display:inline-block;margin-top:6px}.dash .recent-list{margin-top:8px;display:grid;gap:10px}.dash .recent-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;padding:18px 20px;box-shadow:var(--shadow-1);position:relative;transition:box-shadow .2s ease,border-color .2s ease,background .2s ease}.dash .recent-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand);border-radius:14px 0 0 14px;opacity:0;transition:opacity .2s ease}.dash .recent-item:hover{border-color:var(--brand-100);box-shadow:0 4px 12px #0000000f;background:#f8fafc}.dash .recent-item:hover:before{opacity:1}.dash .recent-title{font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink);margin-bottom:4px}.dash .chips{display:flex;gap:8px;margin-top:4px;align-items:center}.dash .chip{background:#f1f5f9;color:var(--muted);padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600}.dash .recent-progress{font-weight:700;color:var(--brand);font-size:16px}.dash .divider{height:1px;background:var(--line);margin:24px 0}.dash .sec-ttl{margin:28px 0 16px;font-size:15px;font-weight:700;letter-spacing:.06em;color:var(--ink);text-transform:uppercase;white-space:nowrap}.dash .sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:nowrap}.dash .sec-link{font-size:13px;color:var(--muted);text-decoration:none;white-space:nowrap}.dash .sec-link:hover{color:var(--brand);text-decoration:underline}.dash .log-item{border:1.5px solid #e2e8f0;background:#f8fafc;border-radius:14px;padding:20px 24px 20px 56px;box-shadow:var(--shadow-1);position:relative;transition:box-shadow .2s ease,border-color .2s ease,background .2s ease;display:flex;justify-content:space-between;gap:12px}.dash .log-item:before{content:"📝";position:absolute;left:20px;top:20px;font-size:22px}.dash .log-item:hover{border-color:var(--brand-100);box-shadow:0 4px 12px #0000000f;background:#fff}.dash .log-date{color:var(--muted);margin-bottom:8px;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.06em}.dash .log-text{line-height:1.6;color:var(--ink);font-size:14px}.dash .log-actions{display:flex;align-items:flex-start}.dash .log-edit-btn{background:transparent;border:none;padding:4px;border-radius:8px;cursor:pointer;color:var(--muted)}.dash .log-edit-btn svg{width:18px;height:18px}.dash .log-edit-btn:hover{background:#e2e8f0;color:var(--ink)}.modal-backdrop{position:fixed;inset:0;background:#0206178c;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:saturate(120%) blur(2px);backdrop-filter:saturate(120%) blur(2px)}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);width:560px;max-width:92vw;padding:18px;border:1px solid var(--line)}.modal-title{margin:0;font-size:18px;font-weight:800;letter-spacing:-.01em}.modal-close{background:transparent;border:0;font-size:22px;line-height:1;cursor:pointer;border-radius:8px}.modal-close:hover{background:#f1f5f9}.modal-row{display:flex;align-items:center;gap:10px;margin:10px 0 25px}.modal-label{min-width:56px;color:var(--muted);font-size:14px}.modal-date-input{height:38px;border:1px solid var(--line);border-radius:10px;padding:0 10px;font:inherit;background:var(--surface);color:var(--ink)}.modal-date{color:var(--muted);margin-bottom:8px}.modal-textarea{width:100%;min-height:250px;border:1px solid var(--line);border-radius:12px;padding:12px;font-size:16px;font:inherit;line-height:1.5;resize:vertical;background:#fff}.modal-textarea:focus{outline:2px solid var(--brand-100);outline-offset:1px}.dash a:focus,.dash button:focus,.modal-close:focus,.modal-date-input:focus{outline:2px solid var(--brand-100);outline-offset:2px}@media(max-width:980px){.dash .lesson-grid,.dash .act-grid,.dash .stats-grid{grid-template-columns:1fr}}.mobile-topbar{display:none}@media(max-width:768px){.dash-sidebar{width:240px;min-width:240px;transform:translate(-100%);transition:transform .3s ease;z-index:1000}.dash-sidebar.open{transform:translate(0)}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:8px;margin-left:auto;transition:background .2s ease,color .2s ease}.sidebar-close-btn:hover{background:var(--brand-soft);color:var(--brand-600)}.sidebar-overlay{position:fixed;inset:0;background:#00000073;z-index:900;display:block;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dash-main{margin-left:0;width:100%;position:relative}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;position:sticky;top:0;z-index:95;background:var(--bg);border-bottom:1px solid rgba(148,163,184,.2)}.mobile-logo{display:inline-flex;align-items:center;gap:10px}.mobile-logo-icon{width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,#ff8c00,#ff6b00);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #ff8c0040}.mobile-logo-text{font-weight:700;letter-spacing:.08em;font-size:15px;background:linear-gradient(135deg,var(--brand) 0%,#065f46 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:#fff;border-radius:14px;box-shadow:0 8px 30px #0f172a1f;cursor:pointer;color:var(--ink);transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.mobile-menu-btn:hover{background:var(--brand-soft);box-shadow:0 10px 32px #0f172a26}.mobile-menu-btn:active{transform:scale(.95)}.dash .dash-wrap{padding:24px 20px 40px}}@media(min-width:769px){.mobile-topbar,.mobile-menu-btn,.sidebar-close-btn,.sidebar-overlay{display:none}}@media(prefers-reduced-motion:reduce){.dash *{transition:none!important}}:root{--bg-dim: rgba(15, 23, 42, .55);--card: #fff;--ink: #0f172a;--muted: #6b7280;--ring: #DFF7E5;--brand: #0A8059;--brand-hover: #065f46;--accent: #4CAF50;--shadow-lg: 0 20px 60px rgba(2,6,23,.25), 0 6px 20px rgba(2,6,23,.08);--radius: 16px}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--ink)}.login-overlay{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(1200px 600px at 20% 10%,rgba(134,239,172,.25),transparent 60%),radial-gradient(1000px 600px at 80% 90%,rgba(187,247,208,.25),transparent 60%),var(--bg-dim);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);padding:24px}.login-modal{position:relative;width:100%;max-width:540px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px;animation:pop .18s ease-out}@keyframes pop{0%{transform:translateY(6px) scale(.98);opacity:.6}to{transform:translateY(0) scale(1);opacity:1}}.close-btn{position:absolute;top:10px;right:12px;width:32px;height:32px;border-radius:999px;border:0;background:transparent;font-size:22px;line-height:32px;color:#475569;cursor:pointer}.close-btn:hover{background:#f1f5f9}.login-modal h2{margin:4px 0 6px;font-size:22px;letter-spacing:-.01em}.subtext{margin:0 0 14px;color:var(--muted)}.divider{height:1px;width:100%;background:#e5e7eb;margin:16px 0 18px;border-radius:1px}.google-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border-radius:999px;border:1px solid #e5e7eb;background:#fff;font-weight:600;cursor:pointer;box-shadow:0 2px #0f172a05}.google-btn:hover{background:#fafafa}.google-btn:focus{outline:2px solid var(--ring);outline-offset:2px}.g-icon{width:20px;height:20px}@media(min-width:640px){.login-modal{padding:32px}}@media(prefers-color-scheme:dark){:root{--card: #111827;--ink: #f9fafb;--muted: #9ca3af;--bg-dim: rgba(0,0,0,.6)}.login-modal{box-shadow:0 20px 60px #0000008c}.google-btn{background:#0b1220;border-color:#25314a}.google-btn:hover{background:#0f172a}.divider{background:#293142}.close-btn{color:#cbd5e1}.close-btn:hover{background:#1f2937}}.onb{--onb-bg:#f7f9fb;--onb-card:#ffffff;--onb-line:#e2e8f0;--onb-ink:#0f172a;--onb-muted:#64748b;--onb-brand:#0a8059;--onb-brand-700:#065f46;--onb-ring:#0a8059;--onb-shadow:0 18px 40px rgba(15,23,42,.12);font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,sans-serif;background:var(--onb-bg);min-height:100vh}.dash-wrap .onb{background:transparent;min-height:auto}.onb-wrap{max-width:900px;margin:0 auto;padding:32px 16px 40px}.dash-wrap .onb-wrap{max-width:100%;margin:0;padding:0}.onb-card{background:var(--onb-card);border-radius:18px;border:1px solid var(--onb-line);box-shadow:var(--onb-shadow);padding:24px 22px 26px}.onb-card.wide{padding-inline:28px}.onb-brand{width:40px;height:40px;border-radius:14px;background:#0a8059;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;margin-bottom:10px}.onb-title{margin:0 0 4px;font-size:32px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#065f46,#0a8059);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.onb-sub{margin:0 0 20px;color:var(--onb-muted);font-size:14px}.onb-form{display:flex;flex-direction:column;gap:24px}.onb .basic-row{display:grid;gap:14px}@media(min-width:900px){.onb .basic-row{grid-template-columns:2fr 1fr 1.5fr;align-items:start}}@media(max-width:899px){.onb .basic-row{grid-template-columns:1fr}}.onb .field-country{min-width:0;position:relative}.onb .field-country select{width:100%;min-width:0;box-sizing:border-box}.onb .field{display:flex;flex-direction:column;gap:6px}.onb .field span{font-size:13px;font-weight:600;color:var(--onb-ink);line-height:1.4;height:18px;display:block}.onb input,.onb select{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--onb-line);background:#f8fafc;font-size:14px;box-sizing:border-box;height:42px}.onb select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.onb-toast{position:fixed;bottom:24px;right:24px;z-index:10000;animation:slideUpToast .3s ease-out}@keyframes slideUpToast{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.onb-toast-content{display:flex;align-items:center;gap:12px;background:#0a8059;color:#fff;padding:14px 20px;border-radius:12px;box-shadow:0 4px 16px #0a80594d;min-width:240px;max-width:400px}.onb-toast-icon{width:24px;height:24px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.onb-toast-text{flex:1;font-size:14px;font-weight:500;line-height:1.4}@media(max-width:768px){.onb-toast{bottom:16px;right:16px;left:16px}.onb-toast-content{min-width:auto;width:100%}}.onb input:focus,.onb select:focus{outline:2px solid var(--onb-ring);outline-offset:1px}.onb .hint{margin:-2px 0 8px;font-size:13px;color:var(--onb-muted)}.onb .chips{display:flex;flex-wrap:wrap;gap:8px}.onb .chip{padding:8px 12px;border-radius:999px;border:1px solid var(--onb-line);background:#fff;font-size:13px;cursor:pointer}.onb .chip.active{border-color:#0a8059;background:#ecfdf5;color:#065f46}.onb .row-end{display:flex;justify-content:flex-end;margin-top:8px}.onb .btn-add{padding:8px 14px;border-radius:10px;border:1px solid var(--onb-line);background:#fff;font-size:13px;font-weight:600;cursor:pointer}.onb .btn-add.large{padding-inline:18px}.onb .learn-inline{display:grid;gap:10px}@media(min-width:900px){.onb .learn-inline{grid-template-columns:2fr minmax(200px,1.5fr) auto;align-items:start}}.onb .learn-inline input{width:100%}.onb .seg{display:flex;border-radius:10px;border:1px solid var(--onb-line);overflow:hidden}.onb .seg-btn{flex:1;padding:8px 10px;border:0;background:#fff;font-size:13px;font-weight:600;cursor:pointer}.onb .seg-btn+.seg-btn{border-left:1px solid var(--onb-line)}.onb .seg-btn.active{background:#0a8059;color:#fff;font-weight:600}.onb .selected-languages{margin-top:16px}.onb .learning-items-list{display:flex;flex-direction:column;gap:10px}.onb .learning-item-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:#f8fafc;border:none;border-radius:10px;transition:all .2s}.onb .learning-item-card:hover{background:#ecfdf5}.onb .learning-item-info{display:flex;align-items:center;gap:12px;flex:1}.onb .learning-item-name{font-size:14px;font-weight:600;color:var(--onb-ink);min-width:80px}.onb .learning-level-select{padding:6px 10px;border-radius:8px;border:1px solid var(--onb-line);background:#fff;font-size:13px;font-weight:500;color:var(--onb-ink);cursor:pointer;min-width:120px}.onb .learning-level-select:focus{outline:2px solid var(--onb-ring);outline-offset:1px}.onb .learning-item-remove{border:0;background:transparent;cursor:pointer;font-size:20px;line-height:1;color:#6b7280;padding:4px 8px;border-radius:6px;transition:all .2s;flex-shrink:0}.onb .learning-item-remove:hover{background:#fee2e2;color:#dc2626}.onb .mode-grid{display:grid;gap:12px}@media(min-width:760px){.onb .mode-grid.two{grid-template-columns:1fr 1fr}}.onb .mode{text-align:left;border-radius:14px;border:none;padding:18px 20px;background:#fff;cursor:pointer;transition:all .2s}.onb .mode .m-title{font-weight:700;font-size:15px;margin-bottom:6px;color:var(--onb-ink)}.onb .mode .m-desc{font-size:13px;color:var(--onb-muted);line-height:1.5}.onb .mode.active{border:none;background:#ecfdf5;box-shadow:0 2px 8px #0a80591a}.onb .btn-primary{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--onb-brand);background:var(--onb-brand);color:#fff;font-weight:700;font-size:15px;cursor:pointer}.onb .btn-primary:disabled{opacity:.6;cursor:not-allowed;border-color:#cbd5e1;background:#94a3b8}:root{--bg: #F7F9F9;--ink: #0f172a;--muted: #313c4d;--line: #e2e8f0;--brand: #0A8059;--brand-50: #DFF7E5;--brand-100: #DFF7E5;--accent: #4CAF50;--brand-200: #a7f3d0;--brand-300: #6ee7b7;--brand-500: #0a8059;--brand-600: #065f46;--brand-700: #047857;--brand-800: #065f46;--chip: #f1f5f9;--chip-active: #ecfdf5;--card: #ffffff;--glass: blur(20px) saturate(1.1);--shadow: 0 1px 3px rgba(0,0,0,.05), 0 10px 30px rgba(0,0,0,.08);--shadow-lg: 0 4px 6px rgba(0,0,0,.05), 0 20px 40px rgba(0,0,0,.1);--shadow-brand: 0 4px 12px rgba(10,128,89,.15);--radius: 16px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--ink);background:linear-gradient(135deg,#f7f9f9 0% 50%,#dff7e5);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.match{padding:20px 0 20px 00px;min-height:100vh}.match-wrap{max-width:1100px;margin:0 auto}.match-top{display:flex;align-items:center;gap:16px;margin-bottom:20px}.btn-icon{appearance:none;border:1.5px solid var(--line);border-radius:12px;padding:10px 16px;background:#fff;cursor:pointer;font-weight:600;font-size:14px;transition:background .2s ease,border-color .2s ease;color:var(--ink)}.btn-icon:hover{background:#f8fafc;border-color:#cbd5e1}.btn-icon:focus{outline:none!important;border-color:var(--brand-500)!important}.title{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0;color:#0f172a;background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.grid2{display:grid;gap:30px}@media(min-width:920px){.grid2{grid-template-columns:1fr 1fr}}.match .card,.match-wrap .card,.grid2 .card{backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass);background:var(--card)!important;border:none!important;border-radius:var(--radius);box-shadow:var(--shadow)!important;padding:32px;transition:none!important;transform:none!important;pointer-events:auto}.match .card:hover,.match .card:active,.match .card:focus,.match-wrap .card:hover,.match-wrap .card:active,.match-wrap .card:focus,.grid2 .card:hover,.grid2 .card:active,.grid2 .card:focus,section.card:hover,section.card:active,section.card:focus,section:hover.card,.grid2>section:hover,.grid2>section:active,.grid2>section:focus,.grid2>.card:hover,.grid2>.card:active,.grid2>.card:focus,.match section.card:hover,.match section.card:active,.match section.card:focus{background:var(--card)!important;border:none!important;box-shadow:var(--shadow)!important;transform:none!important;opacity:1!important;filter:none!important;cursor:default!important;outline:none!important;scale:1!important}.match .card *,.match-wrap .card *,.grid2 .card *{pointer-events:auto}.card-title{font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:10px;font-size:22px;color:#0f172a;letter-spacing:-.01em}.card-subtitle{font-size:14px;color:var(--muted);margin:0 0 32px;line-height:1.6;font-weight:400;margin-bottom:20px!important}.field{display:grid;gap:12px;margin-bottom:24px}.field:last-child{margin-bottom:0}.lbl{font-weight:700;font-size:15px;color:#1e293b;letter-spacing:-.01em;margin-bottom:0}.field-hint{font-size:13px;color:var(--muted);margin:0 0 15px;line-height:1.5;font-weight:400}.row{display:grid;grid-template-columns:1fr 160px;gap:12px;align-items:start}@media(max-width:520px){.row{grid-template-columns:1fr}}.input{width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-size:15px;transition:all .2s ease;color:#0f172a;font-weight:500}.input::placeholder{color:#94a3b8;font-weight:400}.field-korean-level .input:hover{border-color:var(--brand-300);background:#fafbfc;cursor:pointer;box-shadow:0 0 0 2px #0a80590d;transition:all .2s ease}.field-korean-level select.input:hover{border-color:var(--brand-500);color:var(--brand-500)}.input:focus{outline:none!important;border-color:var(--brand-500)!important;background:#fff;box-shadow:0 0 0 4px #0a80591a}.input:disabled{background:#f8faf9;color:#94a3b8;cursor:not-allowed;border-color:#e2e8f0}select.input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230a8059' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;color:var(--brand-500);font-weight:600}select.input:focus{outline:none!important;border-color:var(--brand-500)!important;box-shadow:0 0 0 4px #0a80591a;color:var(--brand-500)}select.input option{color:var(--brand-500);font-weight:600}.seg{display:flex;gap:10px;flex-wrap:wrap}.seg-btn{padding:12px 20px;border-radius:12px;border:1.5px solid var(--line);background:#fff;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px;transition:background .2s ease,border-color .2s ease,color .2s ease;font-size:14px;color:#475569;flex:1;min-width:fit-content;justify-content:center}.seg-btn:hover{background:#f8fafc;border-color:#cbd5e1}.seg-btn:focus{outline:none!important;border-color:var(--brand-500)!important}.seg-btn.active{border-color:var(--brand-500)!important;background:#ecfdf5;color:var(--brand-700);font-weight:700}.seg-btn.active:focus{outline:none!important;border-color:var(--brand-500)!important}.chips{display:flex;flex-wrap:wrap;gap:10px}.chip{background:var(--brand-50);color:var(--brand-700);padding:8px 16px;border-radius:24px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-size:14px;transition:background .2s ease;border:1.5px solid var(--brand-100)}.chip:hover{background:var(--brand-100)}.chip-btn{background:#fff;border:none;border-radius:24px;padding:8px 18px;cursor:pointer;font-weight:600;font-size:14px;transition:background .2s ease,border .2s ease,color .2s ease;color:#475569;outline:none}.chip-btn:hover{background:#f1f5f9}.chip-btn:focus{outline:none!important;border:1.5px solid var(--brand-500)!important}.chip-btn.active{background:#ecfdf5;border:1.5px solid var(--brand-500)!important;outline:none!important;color:var(--brand-700);font-weight:700}.chip-btn.active:focus{outline:none!important;border:1.5px solid var(--brand-500)!important}.range{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;background:transparent;outline:none;position:relative;margin:0;padding:0}.range::-webkit-slider-runnable-track{height:8px;border-radius:999px;background:transparent}.range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 2px 8px #0a80594d;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease;position:relative;margin-top:-6px}.range::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 3px 12px #0a805966}.range::-webkit-slider-thumb:active{transform:scale(1.2)}.range-min::-webkit-slider-thumb{background:var(--brand-600)}.range-max::-webkit-slider-thumb{background:var(--brand-600)}.range::-moz-range-track{height:8px;border-radius:999px;background:transparent}.range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--brand);border:3px solid #fff;box-shadow:0 2px 8px #0a80594d;cursor:pointer;transition:transform .1s ease}.range::-moz-range-thumb:hover{transform:scale(1.15)}.range::-moz-range-thumb:active{transform:scale(1.2)}.badge{background:var(--brand-50);border:1.5px solid var(--brand-200);color:var(--brand-700);border-radius:12px;font-weight:700;padding:8px 16px;font-size:14px}.cta{display:grid;justify-items:center;gap:16px;margin:0 0 16px}.btn-primary{appearance:none;border:0;cursor:pointer;padding:16px 32px;border-radius:14px;color:#fff;font-weight:700;font-size:16px;letter-spacing:-.01em;background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-600) 100%);box-shadow:0 4px 12px #0a805940;transition:background .2s ease,box-shadow .2s ease;text-align:center}.btn-primary:hover{box-shadow:0 6px 16px #0a80594d;filter:brightness(1.05)}.btn-primary:active{filter:brightness(.95)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.note{color:var(--muted);font-size:14px;text-align:center;line-height:1.6;max-width:500px}.list{display:grid;gap:12px;margin-top:10px}.item{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}.item-main{flex:1;display:flex;flex-direction:column;gap:8px}.item-actions{display:flex;align-items:center;gap:8px}.item-name{font-weight:800}.item .btn-outline{appearance:none;background:transparent;border:1.5px solid var(--brand);color:var(--brand);padding:8px 12px;border-radius:10px;font-weight:800;cursor:pointer}.item .btn-outline:hover{background:#f0fbf5}.item .btn-outline:disabled{opacity:.6;cursor:not-allowed;transform:none}.searching-status{display:flex;justify-content:center;align-items:center;padding:40px 20px;min-height:400px}@media(max-width:640px){.item{flex-direction:column;align-items:flex-start}.item-actions{width:100%!important;flex-direction:column!important;align-items:stretch!important}.item-actions button{width:100%!important;justify-content:center}.item-main .chips{width:100%;justify-content:flex-start}}.searching-status-card{background:linear-gradient(135deg,#fff,#f8fffe);border-radius:24px;padding:48px 40px;max-width:500px;width:100%;box-shadow:0 8px 32px #0a80591f,0 2px 8px #0a805914;border:1px solid rgba(10,128,89,.1);text-align:center;position:relative;overflow:hidden}.searching-status-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brand-500) 0%,var(--brand-300) 50%,var(--brand-500) 100%);background-size:200% 100%;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.searching-indicator{display:flex;flex-direction:column;align-items:center;gap:24px;margin-bottom:32px}.pulse-container{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.pulse-dot{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-600) 100%);box-shadow:0 0 #0a8059b3,0 0 #0a8059b3;animation:pulse-dot 2s cubic-bezier(.4,0,.6,1) infinite;position:relative;z-index:2}.pulse-ring{position:absolute;width:80px;height:80px;border-radius:50%;border:3px solid var(--brand-300);animation:pulse-ring 2s cubic-bezier(.4,0,.6,1) infinite;opacity:.6}@keyframes pulse-dot{0%,to{transform:scale(1);box-shadow:0 0 #0a8059b3,0 0 #0a8059b3}50%{transform:scale(1.1);box-shadow:0 0 0 8px #0a805900,0 0 0 16px #0a805900}}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.8}50%{transform:scale(1.2);opacity:.3}to{transform:scale(1.4);opacity:0}}.searching-text{display:flex;flex-direction:column;gap:8px;align-items:center}.searching-title{font-size:22px;font-weight:700;color:var(--brand-700);letter-spacing:-.02em;background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.searching-subtitle{font-size:14px;color:var(--muted);font-weight:500;opacity:.8}.searching-actions{margin-bottom:24px}.btn-stop-search{appearance:none;border:2px solid var(--line);background:#fff;color:var(--muted);padding:14px 28px;border-radius:14px;font-weight:700;font-size:15px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:10px;box-shadow:0 2px 8px #0000000d}.btn-stop-search:hover{background:#f8fafc;border-color:#cbd5e1;color:#475569;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.btn-stop-search:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.btn-stop-search span:first-child{font-size:18px}.searching-note{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 20px;background:linear-gradient(135deg,var(--brand-50) 0%,#f0fdf4 100%);border-radius:12px;border:1px solid var(--brand-100);font-size:14px;color:var(--brand-700);font-weight:500;line-height:1.5}.note-icon{font-size:18px;flex-shrink:0}@media(max-width:640px){.searching-status{padding:20px 16px;min-height:300px}.searching-status-card{padding:32px 24px}.pulse-container,.pulse-ring{width:60px;height:60px}.searching-title{font-size:18px}.searching-subtitle{font-size:13px}.btn-stop-search{padding:12px 24px;font-size:14px}}.match-notification{position:fixed;top:20px;right:20px;z-index:1000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.match-notification-content{background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-600) 100%);color:#fff;padding:16px 20px;border-radius:12px;box-shadow:0 8px 24px #0a80594d;display:flex;align-items:center;gap:12px;min-width:320px;max-width:400px}.match-notification-icon{font-size:32px;flex-shrink:0}.match-notification-text{flex:1}.match-notification-text strong{display:block;font-size:16px;margin-bottom:4px}.match-notification-text div{font-size:14px;opacity:.95}.match-notification-close{background:#fff3;border:none;color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.match-notification-close:hover{background:#ffffff4d}@media(max-width:768px){.match-notification{top:10px;right:10px;left:10px}.match-notification-content{min-width:auto;max-width:none}}.connection-request-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:20px;z-index:2000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.connection-request-modal:has(.connection-request-header h3:contains("Request Accepted")){align-items:flex-start;padding-top:20px}.connection-request-content{background:#fff;border-radius:16px;padding:24px;max-width:400px;width:90%;box-shadow:0 20px 50px #0000004d;animation:slideUp .3s ease-out;border:1px solid var(--line)}.connection-request-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.connection-request-header h3{margin:0;font-size:20px;color:var(--ink);font-weight:800}.connection-request-close{background:transparent;border:none;font-size:24px;color:var(--muted);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.connection-request-close:hover{background:var(--brand-50);color:var(--brand-700)}.connection-request-body{margin-bottom:20px}.connection-request-body p{margin:0;font-size:16px;color:var(--ink);line-height:1.5}.connection-request-actions{display:flex;gap:12px;justify-content:flex-end}.btn-reject{padding:10px 20px;border:1.5px solid var(--line);border-radius:10px;background:#fff;color:var(--muted);font-weight:700;cursor:pointer;transition:all .2s}.btn-reject:hover{background:#f9fafb;border-color:#cbd5e1}.btn-accept{padding:10px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #0a80594d;transition:box-shadow .2s,transform .1s}.btn-accept:hover{box-shadow:0 6px 16px #0a805966}.btn-accept:active{transform:translateY(1px)}.profile-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.profile-modal-content{background:#fff;border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out;border:1px solid var(--line);display:flex;flex-direction:column}.profile-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 28px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#f8fffe,#fff);border-radius:20px 20px 0 0}.profile-modal-header h2{margin:0;font-size:24px;color:var(--ink);font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--brand-600) 0%,var(--brand-500) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-modal-close{background:transparent;border:none;font-size:28px;color:var(--muted);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;line-height:1}.profile-modal-close:hover{background:var(--brand-50);color:var(--brand-700);transform:rotate(90deg)}.profile-modal-body{padding:28px;flex:1;overflow-y:auto}.profile-section{margin-bottom:32px}.profile-section:last-child{margin-bottom:0}.profile-name{font-size:28px;font-weight:800;color:var(--ink);margin-bottom:16px;letter-spacing:-.02em}.profile-basic-info{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--line)}.profile-info-item{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--muted)}.profile-info-item strong{color:var(--ink);font-weight:700}.profile-section-title{font-size:18px;font-weight:700;color:var(--ink);margin:0 0 16px;letter-spacing:-.01em}.profile-chips{display:flex;flex-wrap:wrap;gap:10px}.profile-chip{background:var(--brand-50);color:var(--brand-700);padding:10px 18px;border-radius:24px;font-weight:600;font-size:14px;border:1.5px solid var(--brand-100);display:inline-flex;align-items:center}.profile-learning-langs{display:flex;flex-direction:column;gap:12px}.profile-learning-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(135deg,#f8fffe,#fff);border-radius:12px;border:1.5px solid var(--brand-100);transition:all .2s}.profile-learning-item:hover{border-color:var(--brand-300);box-shadow:0 2px 8px #0a80591a}.profile-lang-name{font-size:16px;font-weight:700;color:var(--ink)}.profile-lang-level{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:700;text-transform:capitalize}.profile-lang-level-beginner{background:#dbeafe;color:#1e40af}.profile-lang-level-intermediate{background:#fef3c7;color:#92400e}.profile-lang-level-advanced{background:#d1fae5;color:#065f46}.profile-modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:20px 28px;border-top:1px solid var(--line);background:#f8fafc;border-radius:0 0 20px 20px}.btn-profile-close{padding:12px 24px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--muted);font-weight:700;cursor:pointer;transition:all .2s;font-size:15px}.btn-profile-close:hover{background:#f9fafb;border-color:#cbd5e1;color:var(--ink)}.btn-profile-connect{padding:12px 24px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-600) 100%);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #0a80594d;transition:all .2s;font-size:15px}.btn-profile-connect:hover{box-shadow:0 6px 16px #0a805966;transform:translateY(-1px)}.btn-profile-connect:active{transform:translateY(0)}@media(max-width:640px){.profile-modal{padding:10px}.profile-modal-content{max-height:95vh}.profile-modal-header{padding:20px}.profile-modal-header h2{font-size:20px}.profile-modal-body{padding:20px}.profile-name{font-size:24px}.profile-basic-info{flex-direction:column;gap:12px}.profile-modal-actions{flex-direction:column-reverse;padding:16px 20px}.btn-profile-close,.btn-profile-connect{width:100%}}:root{--bg:#F7F9F9;--card:#ffffff;--border:#e9eef4;--text:#0f172a;--muted:#313c4d;--primary:#0A8059;--primary-600:#065f46;--accent:#4CAF50;--secondary:#DFF7E5;--soft:#f1f5f9;--shadow:0 12px 40px rgba(15,23,42,.12);--radius:14px}.dash{background:var(--bg);min-height:100vh}.dash-wrap{max-width:1100px;margin:0 auto;padding:24px 16px}.dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.dash-title{margin:0 0 4px;font-size:24px;font-weight:800;color:var(--text)}.dash-sub{margin:0;color:var(--muted)}.dash-actions{display:flex;gap:10px;flex-wrap:wrap}.dash .btn-primary,.dash .btn-outline,.dash .btn-link{font:inherit;cursor:pointer;border-radius:10px;height:36px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s ease,border-color .2s ease,opacity .2s ease;text-decoration:none;box-sizing:border-box}.dash .btn-primary{background:var(--primary)!important;color:#fff!important;border:1px solid var(--primary)!important;font-weight:600}.dash .btn-primary:hover:not(:disabled){background:var(--primary-600)!important;border-color:var(--primary-600)!important}.dash .btn-primary:active:not(:disabled){background:var(--primary-600)!important}.dash .btn-primary:disabled{opacity:.6!important;cursor:not-allowed!important}.dash .btn-outline{background:#fff;color:var(--text);border:1px solid var(--border)}.dash .btn-outline:hover:not(:disabled){background:var(--soft)}.dash .btn-outline:disabled{opacity:.5;cursor:not-allowed}.dash .btn-link{background:transparent;border:0;padding:0;color:var(--primary);height:auto}.dash .btn-link:hover{text-decoration:underline}.muted{color:var(--muted)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-title{font-weight:700;display:flex;align-items:center;gap:8px}.gd-list{display:flex;flex-direction:column;gap:24px}.gd-month-title{margin:6px 2px 10px;font-size:16px;font-weight:800;color:var(--text)}.gd-items{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff}.gd-item{display:grid;grid-template-columns:200px 40px 1fr 90px;gap:12px;padding:14px 16px;border-top:1px solid var(--border)}.gd-item:first-child{border-top:0}.gd-col.gd-date{color:var(--muted)}.gd-date-main{font-size:14px;font-weight:600}.gd-date-time{font-size:12px;margin-top:2px}.gd-col.gd-icon{display:flex;align-items:flex-start;justify-content:center;padding-top:2px}.gd-icon-log{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f0fdf4;border-radius:8px;color:var(--primary)}.gd-icon-session{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:#fff}.gd-icon-session.gd-icon-quiet{background:#0a8059}.gd-icon-session.gd-icon-active{background:#3b82f6}.gd-col.gd-text{white-space:pre-wrap;line-height:1.55}.gd-entry-type{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.gd-entry-content{font-size:14px;line-height:1.6}.gd-session-info{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.gd-session-partner{font-weight:400;color:var(--text)}.gd-session-duration{font-size:13px}.gd-session-status{display:inline-block;padding:2px 8px;background:#fef3c7;color:#92400e;border-radius:4px;font-size:12px;font-weight:600;margin-top:4px}.gd-col.gd-actions{display:flex;justify-content:flex-end;align-items:flex-start}.gd-pagination{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.gd-pagination-info{color:var(--muted);font-size:14px;font-weight:500}.gd-pagination .btn-outline:disabled{opacity:.5;cursor:not-allowed}.btn-log-today .btn-text{display:inline}.btn-log-today .btn-icon-only{display:none}@media(max-width:720px){.gd-item{grid-template-columns:1fr;gap:8px}.gd-col.gd-icon,.gd-col.gd-actions{justify-content:flex-start}.gd-pagination{flex-direction:column;gap:12px}.gd-pagination-info{order:-1}.btn-log-today{min-width:36px;padding:0;width:36px}.btn-log-today .btn-text{display:none}.btn-log-today .btn-icon-only{display:inline;font-size:20px;line-height:1}}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;width:560px;max-width:92vw;border-radius:16px;box-shadow:var(--shadow);padding:18px}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.modal-head-text{max-width:calc(100% - 40px)}.modal-title{margin:0;font-weight:800;font-size:18px;color:var(--text)}.modal-desc{margin:4px 0 0;color:var(--muted);font-size:14px;line-height:1.5}.modal-close{background:transparent;border:0;font-size:22px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:8px}.modal-close:hover{background:var(--soft)}.modal-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.modal-label{font-weight:600;font-size:14px;color:var(--text)}.modal-date-input{border:1px solid var(--border);border-radius:8px;padding:6px 10px;font:inherit}.modal-date{color:var(--muted);font-size:13px}.modal-textarea{width:100%;min-height:150px;border:1px solid var(--border);border-radius:12px;padding:12px;resize:vertical;font:inherit}.modal-tip{color:var(--muted);font-size:13px;margin-top:8px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}.okr-wrap{max-width:880px;margin:32px auto;padding:0 20px}.okr-header h2{margin:0 0 6px}.muted{color:#6b7280;font-size:14px}.banner{margin-top:10px;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:10px 12px;border-radius:10px}.wizard{margin-top:18px}.okr-section{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;margin-bottom:12px}.okr-section h3{margin:0 0 8px;font-size:15px}.input{width:100%;border:1px solid #e5e7eb;border-radius:10px;padding:10px 12px;outline:none}.input:focus{border-color:#22c55e;box-shadow:0 0 0 3px #22c55e26}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:860px){.grid-3{grid-template-columns:1fr}}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid #e5e7eb;background:#fff;padding:6px 10px;border-radius:999px;font-size:13px}.chip--active{background:#e8f7ee;border-color:#22c55e;color:#14532d}.actions{display:flex;align-items:center;gap:12px;margin-top:8px}.btn{border:1px solid #d1d5db;background:#fff;padding:8px 14px;border-radius:10px;cursor:pointer}.btn:hover{background:#f9fafb}.btn.primary{background:#22c55e;border-color:#16a34a;color:#fff}.btn.primary:hover{background:#16a34a}.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;padding:10px 12px;border-radius:10px}.loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 0}.spinner{width:28px;height:28px;border-radius:999px;border:3px solid #e5e7eb;border-top-color:#22c55e;animation:spin 1s linear infinite}.preview{display:grid;gap:12px;margin-top:10px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px}.card h4{margin:0 0 8px}.obj-title{font-weight:600}.kr-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.kr-title{font-weight:500}.kr-meta{display:flex;gap:8px;flex-wrap:wrap;color:#6b7280;font-size:13px}.ms-list{padding-left:20px}.ms-week{display:inline-block;min-width:36px;font-size:12px;color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0;padding:2px 6px;border-radius:999px;margin-right:6px}.hint{color:#6b7280;font-size:12px;margin-top:6px}.jitsi-embed-container{display:flex;flex-direction:column;height:100%;width:100%;background:#1a1a1a;position:relative;overflow:hidden}.jitsi-embed-wrapper{flex:1;position:relative;width:100%;height:100%;min-height:0;display:flex;flex-direction:column;background:#000}.jitsi-embed-wrapper iframe{width:100%;height:100%;border:none}.mode-toggle-section{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:12px}.mode-toggle-container{display:flex;align-items:center;gap:12px;background:#fff;padding:10px 18px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.mode-label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#94a3b8;transition:color .2s}.mode-icon{font-size:18px;line-height:1}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.mode-toggle-switch input:checked+.toggle-slider{background-color:#0a8059}@media(max-width:768px){.jitsi-embed-container{border-radius:0}}.learning-room-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;z-index:100;position:relative}.header-left{flex:0 0 auto}.header-title{display:flex;align-items:center;gap:12px}.header-title h2{margin:0;font-size:20px;font-weight:700;color:#0a8059}.partner-badge{padding:4px 12px;background:#dff7e5;color:#0a8059;border-radius:12px;font-size:13px;font-weight:500}.header-center{flex:1;display:flex;justify-content:center;align-items:center}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.header-action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#374151;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.header-action-btn:hover{background:#f7f9f9;border-color:#0a8059;color:#0a8059}.header-action-btn .action-icon{font-size:16px}.header-action-btn .action-label{font-size:13px}.mode-switcher-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.mode-toggle-container{display:flex;align-items:center;gap:12px;background:#fff;padding:8px 16px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb}.mode-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#94a3b8;transition:color .2s}.mode-label.mode-quiet.active{color:#0a8059}.mode-label.mode-active.active{color:#fbbf24}.mode-icon{font-size:16px;line-height:1}.mode-toggle-switch{position:relative;display:inline-block;width:52px;height:28px;margin:0}.mode-toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#cbd5e1;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.mode-toggle-switch input:checked+.toggle-slider{background-color:#fbbf24}.mode-toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.mode-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;padding:8px 12px;background:#0a8059;color:#fff;border-radius:6px;font-size:12px;white-space:nowrap;z-index:1000;box-shadow:0 4px 12px #00000026}.mode-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#0a8059}.end-session-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;background:#ef4444;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;margin-left:auto}.end-session-btn:hover{background:#dc2626}.end-session-btn .end-icon{font-size:16px}@media(max-width:1024px){.header-action-btn .action-label{display:none}.header-action-btn{padding:8px 12px}}@media(max-width:768px){.learning-room-header{padding:12px 16px;flex-direction:column;gap:12px}.header-left,.header-center{width:100%}.header-actions{width:100%;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.header-action-btn{min-width:0;justify-content:center}.mode-switcher-wrapper{grid-column:1 / span 3;grid-row:2;width:100%;justify-content:center}.mode-toggle-container{width:100%;justify-content:space-between}.end-session-btn{grid-column:4;grid-row:2;width:100%;justify-content:center;margin-left:0;padding:10px;font-size:13px}.header-title h2{font-size:18px}.partner-badge{font-size:12px;padding:3px 10px}}.match-welcome-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.match-welcome-modal{background:#fff;border-radius:24px;padding:32px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.match-welcome-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;color:#94a3b8;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.match-welcome-close:hover{background:#f1f5f9;color:#64748b}.match-welcome-icon{display:flex;justify-content:center;margin-bottom:16px}.match-icon-circle{width:64px;height:64px;background:#dff7e5;border-radius:50%;display:flex;align-items:center;justify-content:center}.match-welcome-title{text-align:center;margin-bottom:12px}.match-confetti{font-size:32px;display:inline-block;margin-right:8px;animation:bounce .6s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.match-welcome-title h2{margin:8px 0 0;font-size:28px;font-weight:700;color:#0a8059;display:inline-block}.match-welcome-message{text-align:center;color:#64748b;font-size:16px;margin-bottom:24px;line-height:1.5}.match-welcome-message strong{color:#0a8059;font-weight:600}.match-mode-box{background:#dff7e5;border-radius:12px;padding:16px;margin-bottom:24px;border:1px solid #a7f3d0}.match-mode-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.match-mode-emoji{font-size:20px}.match-mode-label{font-size:15px;font-weight:600;color:#0a8059}.match-mode-description{font-size:13px;color:#475569;margin:0;line-height:1.5}.match-avatars{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:20px}.match-avatar-container{display:flex;flex-direction:column;align-items:center;gap:8px}.match-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#fff;box-shadow:0 4px 12px #00000026}.match-avatar-user{background:linear-gradient(135deg,#0a8059,#4caf50)}.match-avatar-partner{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.match-avatar-status{width:12px;height:12px;border-radius:50%;background:#4caf50;border:2px solid white;box-shadow:0 2px 4px #0000001a}.match-heart-icon{font-size:24px;animation:pulse 2s ease-in-out infinite}.match-quote{text-align:center;font-size:15px;color:#64748b;font-style:italic;margin-bottom:24px;line-height:1.6}.match-start-button{width:100%;padding:16px 24px;background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s;box-shadow:0 4px 12px #0a80594d}.match-start-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0a805966}.match-start-button:active{transform:translateY(0)}.match-start-arrow{font-size:20px;transition:transform .3s}.match-start-button:hover .match-start-arrow{transform:translate(4px)}.match-bottom-text{text-align:center;font-size:13px;color:#94a3b8;margin-top:16px;margin-bottom:0}@media(max-width:640px){.match-welcome-modal{padding:24px;border-radius:16px}.match-welcome-title h2{font-size:24px}.match-avatar{width:56px;height:56px;font-size:18px}.match-heart-icon{font-size:20px}}.ai-chat-container{position:fixed;bottom:20px;right:20px;z-index:10001;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.ai-chat-panel{background:#fff;border-radius:16px;width:380px;min-height:400px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;animation:slideIn .3s ease-out;overflow:hidden}@keyframes slideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.ai-chat-minimized{position:fixed;bottom:20px;right:20px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;box-shadow:0 4px 16px #0a805966;z-index:10001;transition:all .3s ease;animation:bounceIn .5s ease-out}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.ai-chat-minimized:hover{transform:scale(1.1);box-shadow:0 6px 20px #0a805980}.ai-chat-minimized .minimized-icon{position:relative;display:flex;align-items:center;justify-content:center;color:#fff}.ai-chat-minimized .minimized-icon svg{width:24px;height:24px}.unread-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:12px;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;padding:0 6px;border:2px solid white;animation:pulse 2s infinite}.ai-chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff;border-radius:16px 16px 0 0;flex-shrink:0}.ai-chat-header-info{display:flex;align-items:center;gap:12px}.ai-chat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff40;border-radius:10px;flex-shrink:0;color:#fff}.ai-chat-icon svg{width:28px;height:28px}.ai-chat-header h3{margin:0;font-size:18px;font-weight:700}.ai-chat-header p{margin:4px 0 0;font-size:13px;opacity:.9}.ai-chat-minimize{background:#fff3;border:none;color:#fff;width:44px;height:44px;border-radius:10px;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1}.ai-chat-minimize:hover{background:#ffffff4d}.ai-chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;background:#f7f9f9;min-height:0}.ai-chat-welcome{text-align:center;padding:20px 20px 40px;color:#64748b;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:300px}.welcome-icon{margin-bottom:24px;opacity:.7;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));color:#94a3b8;display:flex;align-items:center;justify-content:center}.welcome-icon svg{width:80px;height:80px}.ai-chat-welcome h4{margin:0 0 12px;font-size:16px;color:#0a8059;font-weight:700;line-height:1.3}.ai-chat-welcome p{margin:0 0 8px;font-size:15px;color:#64748b;line-height:1.6}.ai-chat-welcome p strong{color:#0a8059;font-weight:600}.ai-chat-welcome ul{text-align:left;display:inline-block;margin:16px 0;padding-left:24px}.ai-chat-welcome li{margin:8px 0;font-size:14px}.welcome-hint{margin-top:32px;padding:16px 20px;background:#dff7e5;border-radius:12px;font-size:14px;color:#64748b;text-align:left;display:flex;align-items:flex-start;gap:14px;max-width:500px;width:100%;box-shadow:0 1px 3px #0a80591a;line-height:1.6}.welcome-hint:before{content:"💡";font-size:24px;flex-shrink:0;margin-top:2px;line-height:1;display:block}.welcome-hint-text{flex:1;min-width:0;word-wrap:break-word;overflow-wrap:break-word}.welcome-hint strong{color:#0a8059;font-weight:700}.welcome-hint strong:first-child{color:#0a8059}.welcome-hint-small{display:none}.ai-message{display:flex;gap:12px;align-items:flex-start;animation:messageSlideIn .3s ease-out}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.partner-message,.kora-message{flex-direction:row}.current-user-message{flex-direction:row-reverse}.ai-avatar,.kora-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0a8059,#4caf50);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.user-avatar{width:36px;height:36px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.current-user-avatar{width:36px;height:36px;border-radius:50%;background:#0a8059;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.partner-avatar{width:36px;height:36px;border-radius:50%;background:#64748b;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.kora-message{display:flex;gap:12px;align-items:flex-start}.kora-badge{display:inline-block;margin-left:6px;padding:2px 6px;background:#dff7e5;color:#0a8059;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}.message-content{max-width:75%;min-width:0;display:flex;flex-direction:column;gap:4px;word-wrap:break-word;overflow-wrap:break-word;flex-shrink:1}.current-user-content{align-items:flex-end}.partner-message .message-content,.kora-message .message-content{align-items:flex-start}.current-user-message .message-content{align-items:flex-end}.message-sender{font-size:12px;font-weight:600;color:#0a8059;margin-bottom:2px}.message-text{padding:12px 16px;border-radius:16px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;max-width:100%;width:fit-content;min-width:0;display:inline-block}.message-text .mention-highlight{background:linear-gradient(135deg,#dff7e5,#c8f0d8);color:#0a8059;font-weight:600;padding:3px 8px;border-radius:12px;display:inline-block;box-shadow:0 1px 2px #0a80591a;text-decoration:none;margin:0 2px;white-space:nowrap}.current-user-message .message-text .mention-highlight,.current-user-text .mention-highlight,.current-user-message .mention-highlight{background:#ffffff59!important;color:#fff!important;font-weight:700!important;box-shadow:0 2px 6px #0006,inset 0 1px #fff9!important;border:1.5px solid rgba(255,255,255,.4)!important;padding:4px 10px!important;border-radius:12px!important;display:inline-block!important;white-space:nowrap!important;text-shadow:0 1px 2px rgba(0,0,0,.2)!important}.current-user-message .message-text,.current-user-text{background:#0a8059;color:#fff;border-bottom-right-radius:4px;max-width:100%;width:fit-content;box-shadow:0 1px 2px #0000001a}.partner-message .message-text,.kora-message .message-text{background:#fff;color:#374151;border:1px solid #e5e7eb;border-bottom-left-radius:4px;max-width:100%;width:fit-content;box-shadow:0 1px 2px #0000000d}.message-time{font-size:11px;color:#94a3b8;padding:4px 4px 0;margin-top:2px;align-self:flex-end}.current-user-message .message-time{align-self:flex-end}.partner-message .message-time,.kora-message .message-time{align-self:flex-start}.typing-indicator{display:inline-flex;gap:4px;padding:12px 16px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#94a3b8;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.ai-chat-input-container{display:flex;align-items:flex-end;gap:8px;padding:16px;background:#fff;border-top:1px solid #e5e7eb;position:relative;width:100%}.ai-chat-input-wrapper{flex:1;position:relative;min-width:0;width:100%}.ai-chat-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:24px;font-size:14px;font-family:inherit;resize:none;max-height:120px;overflow-y:auto;outline:none;transition:border-color .2s;box-sizing:border-box;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;min-height:60px}.ai-chat-input:empty:before{content:attr(data-placeholder);color:#9ca3af;pointer-events:none}.ai-chat-input:focus{border-color:#0a8059}.ai-chat-input .input-mention-highlight{background:linear-gradient(135deg,#dff7e5,#c8f0d8);color:#0a8059;font-weight:600;padding:2px 6px;border-radius:8px;display:inline-block;box-shadow:0 1px 2px #0a805926;margin:0 1px}.ai-chat-input[contenteditable=false]{background:#f1f5f9;cursor:not-allowed;opacity:.6}.mention-autocomplete{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:10002;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mention-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid #f1f5f9}.mention-item:last-child{border-bottom:none}.mention-item:hover,.mention-item.selected{background:#dff7e5}.mention-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#0a8059,#4caf50);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.mention-info{flex:1;min-width:0}.mention-name{font-size:14px;font-weight:600;color:#0a8059;display:flex;align-items:center;gap:6px}.mention-badge{display:inline-block;padding:2px 6px;background:#dff7e5;color:#0a8059;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase}.ai-chat-send{width:44px;height:44px;border-radius:50%;border:none;background:#0a8059;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.ai-chat-send:hover:not(:disabled){background:#065f46;transform:scale(1.05)}.ai-chat-send:disabled{background:#cbd5e1;cursor:not-allowed}@media(max-width:768px){.ai-chat-panel{max-height:70vh;border-radius:16px 16px 0 0}.message-content{max-width:85%}}.friend-request-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10003;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.friend-request-modal{background:#fff;border-radius:16px;width:90%;max-width:400px;box-shadow:0 8px 32px #0000004d;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.friend-request-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff}.friend-request-modal-header h3{margin:0;font-size:18px;font-weight:700}.friend-request-modal-close{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;transition:background .2s}.friend-request-modal-close:hover{background:#ffffff4d}.friend-request-modal-body{padding:24px}.friend-request-error{background:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px}.friend-request-content{text-align:center}.friend-request-content p{margin:0 0 12px;font-size:15px;color:#374151;line-height:1.6}.friend-request-content p strong{color:#0a8059;font-weight:600}.friend-request-hint{font-size:13px;color:#64748b;margin-top:8px!important}.friend-request-success-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#dff7e5,#c8f0d8);color:#0a8059;font-size:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-weight:700}.friend-request-btn{padding:12px 24px;border-radius:12px;border:none;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;margin:8px;min-width:120px}.friend-request-btn:disabled{opacity:.6;cursor:not-allowed}.send-btn{background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff}.send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0a80594d}.accept-btn{background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff}.accept-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0a80594d}.decline-btn{background:#f3f4f6;color:#374151}.decline-btn:hover:not(:disabled){background:#e5e7eb}.friend-request-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.video-session-loading,.video-session-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-align:center;padding:24px}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.video-session-error h2{margin:0 0 16px;font-size:24px}.video-session-error p{margin:0 0 24px;opacity:.9}.video-session-error button{padding:12px 24px;border:none;border-radius:8px;background:#fff;color:#667eea;font-weight:600;cursor:pointer;transition:transform .2s ease}.video-session-error button:hover{transform:scale(1.05)}.partner-mode-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:10000;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.notification-content{display:flex;align-items:center;gap:12px;background:#0a8059;color:#fff;padding:14px 20px;border-radius:12px;box-shadow:0 4px 16px #0a80594d;min-width:320px;max-width:500px}.notification-icon{font-size:20px;flex-shrink:0}.notification-text{flex:1;font-size:14px;font-weight:500;line-height:1.4}.notification-close{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;padding:0;line-height:1}.notification-close:hover{background:#ffffff4d}@media(max-width:768px){.partner-mode-notification{left:10px;right:10px;transform:none}.notification-content{min-width:auto;max-width:none}}.request-cancelled-notification{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:10001;animation:slideDownBounce .4s ease-out;max-width:90%;width:100%;max-width:520px}@keyframes slideDownBounce{0%{transform:translate(-50%) translateY(-30px);opacity:0;scale:.9}60%{transform:translate(-50%) translateY(5px);scale:1.02}to{transform:translate(-50%) translateY(0);opacity:1;scale:1}}.request-cancelled-content{display:flex;align-items:flex-start;gap:16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-left:5px solid #f59e0b;color:#92400e;padding:18px 20px;border-radius:16px;box-shadow:0 8px 24px #f59e0b40,0 4px 8px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.request-cancelled-icon{font-size:28px;flex-shrink:0;line-height:1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.request-cancelled-text{flex:1;display:flex;flex-direction:column;gap:6px}.request-cancelled-title{font-size:15px;font-weight:700;line-height:1.4;color:#92400e}.request-cancelled-subtitle{font-size:13px;font-weight:500;line-height:1.4;color:#78350f;opacity:.9}.request-cancelled-close{background:#92400e26;border:none;color:#92400e;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease;padding:0;line-height:1;font-weight:600}.request-cancelled-close:hover{background:#92400e40;transform:scale(1.1)}.request-cancelled-close:active{transform:scale(.95)}@media(max-width:768px){.request-cancelled-notification{left:10px;right:10px;transform:none;max-width:calc(100% - 20px)}.request-cancelled-content{padding:16px 18px;gap:12px}.request-cancelled-title{font-size:14px}.request-cancelled-subtitle{font-size:12px}.request-cancelled-icon{font-size:24px}}.learning-room-container{display:flex;flex-direction:column;height:100vh;background:#f7f9f9;overflow:hidden}.learning-room-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.video-call-section{flex:1;display:flex;flex-direction:column;min-height:0;background:#fff;border-radius:8px;margin:16px;box-shadow:0 2px 8px #0000001a;overflow:hidden}@media(max-width:768px){.video-call-section{margin:8px;border-radius:4px}}.friends-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:16px;color:#64748b}.friends-header{margin-bottom:32px}.friends-header h1{margin:0 0 8px;font-size:32px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#065f46,#0a8059);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.friends-subtitle{margin:0;font-size:15px;color:#64748b}.friends-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e2e8f0;padding-bottom:0}.tab-button{position:relative;padding:12px 24px;border:none;background:transparent;color:#64748b;font-size:15px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;display:flex;align-items:center;gap:8px;transition:all .2s}.tab-button:hover{color:#0a8059;background:#dff7e5;border-radius:8px 8px 0 0}.tab-button.active{color:#0a8059;font-weight:600;border-bottom-color:#0a8059}.tab-badge{background:#0a8059;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:20px;text-align:center}.tab-button.active .tab-badge{background:#0a8059}.friends-tab-content{min-height:400px}.friends-section{background:#fff;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 2px 6px #0206170f}.section-title{display:flex;align-items:center;gap:12px;margin:0 0 20px;font-size:20px;font-weight:600;color:#0f172a}.badge{background:#0a8059;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.friends-list{display:flex;flex-direction:column;gap:12px}.friend-card{display:flex;align-items:center;justify-content:space-between;padding:16px;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s}.friend-card:hover{border-color:#0a8059;box-shadow:0 2px 8px #0a80591a}.request-card{background:#dff7e5}.friend-info{display:flex;align-items:center;gap:12px;flex:1}.friend-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;flex-shrink:0}.friend-details h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#0f172a}.friend-details p{margin:0;font-size:13px;color:#64748b}.friend-actions{display:flex;align-items:center;gap:12px}.mode-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#0a8059;font-weight:500;background:#fff;cursor:pointer}.mode-select:focus{outline:none;border-color:#0a8059}.btn-start-session,.btn-accept,.btn-decline,.btn-cancel{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-start-session{background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff}.btn-start-session:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0a80594d}.btn-start-session:disabled{opacity:.6;cursor:not-allowed}.btn-accept{background:linear-gradient(135deg,#0a8059,#4caf50);color:#fff}.btn-accept:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0a80594d}.btn-decline,.btn-cancel,.btn-delete{background:#f3f4f6;color:#374151}.btn-decline:hover,.btn-cancel:hover,.btn-delete:hover,.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca}.empty-state{text-align:center;padding:48px 24px;color:#64748b}.empty-state p{margin:0 0 8px;font-size:15px}.empty-hint{font-size:13px!important;color:#94a3b8!important}@media(max-width:768px){.friend-card{flex-direction:column;align-items:flex-start;gap:16px}.friend-actions{width:100%;flex-direction:column}.mode-select,.btn-start-session,.btn-accept,.btn-decline,.btn-cancel{width:100%}}.messages-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px;height:calc(100vh - 180px);min-height:520px;align-items:stretch}.messages-sidebar{background:#fff;border-radius:20px;padding:24px 20px;box-shadow:var(--shadow-1);display:flex;flex-direction:column;min-height:0;height:100%}.messages-sidebar-header h2{margin:0;font-size:22px;font-weight:800}.messages-sidebar-header p{margin:4px 0 0;color:#64748b;font-size:14px}.messages-search{margin:18px 0}.messages-search input{width:100%;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;font-size:14px}.messages-friend-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:4px}.friend-item{display:flex;gap:12px;align-items:center;padding:12px;border:1px solid transparent;border-radius:14px;cursor:pointer;background:#f8fafc;text-align:left;transition:border-color .15s ease,background .15s ease}.friend-item:hover,.friend-item.active{border-color:var(--brand-100);background:#fff;box-shadow:0 4px 12px #0f172a14}.friend-avatar{width:44px;height:44px;border-radius:25px;background:var(--brand-soft);border:1px solid rgba(10,128,89,.15);color:var(--brand-600);display:flex;align-items:center;justify-content:center;font-weight:700}.friend-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.friend-name-row{display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:14px;width:100%}.friend-name{font-weight:600;color:#0f172a;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-time{font-size:12px;color:#94a3b8;margin-left:auto}.friend-last-message{font-size:13px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;text-align:left}.friend-unread{background:var(--brand);color:#fff;min-width:22px;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:700;text-align:center}.messages-content{background:#fff;border-radius:20px;box-shadow:var(--shadow-1);display:flex;flex-direction:column;min-height:0;height:100%;max-height:calc(100vh - 180px);overflow:hidden}.messages-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:70vh;color:#94a3b8;text-align:center;gap:8px}.messages-panel{display:flex;flex-direction:column;height:100%;min-height:0;padding-bottom:0}@media(max-width:768px){.messages-panel{height:calc(100vh - 120px)!important}.messages-thread{flex:1;min-height:0;overflow-y:auto}.message-composer{flex-shrink:0}}.messages-panel-header{padding:5px 24px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between;gap:12px}.messages-panel-header-left{display:flex;align-items:center;gap:12px}.mobile-back-btn{display:none;margin-left:5px;border-radius:12px;width:36px;height:36px;align-items:center;justify-content:center;font-size:18px;background:#fff}.messages-thread{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;background:#f9fafb;min-height:0}.message-bubble{max-width:85%;padding:12px 16px;border-radius:18px;line-height:1.4;font-size:14px;background:#fff;align-self:flex-start;box-shadow:0 8px 18px #0f172a14}.message-bubble.me{background:#0a8059;color:#fff;align-self:flex-end}.message-meta{font-size:12px;margin-bottom:4px;display:flex;justify-content:space-between;opacity:.8}.message-meta.subtle{opacity:.5;justify-content:flex-end}.message-composer{align-items:center;border-top:1px solid #e2e8f0;padding:16px 20px;display:flex;gap:12px;background:#fff}.message-composer textarea{flex:1;border:1px solid #e2e8f0;border-radius:14px;padding:12px;min-height:60px;font-family:inherit;font-size:14px;resize:none;outline:none}.message-composer textarea:focus{border-color:#e2e8f0;box-shadow:none}.messages-placeholder{text-align:center;color:#94a3b8;padding:16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.composer-send{width:52px;height:52px;border-radius:16px;border:none;background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-600) 100%);color:#fff;font-size:20px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px #0a805966;cursor:pointer}.composer-send:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.messages-sidebar-header-mobile{display:none}@media(max-width:1024px){.messages-layout{display:flex;flex-direction:column;gap:16px;height:auto}.messages-sidebar{display:flex;order:1;background:transparent;box-shadow:none;padding:0}.messages-content{order:2;flex:1;min-height:0;max-height:none;display:none}.messages-panel{height:100%}.messages-panel-header{display:flex;padding:0}.messages-panel-header .btn-secondary{display:none}.messages-sidebar-header-mobile{display:block}.messages-layout.show-chat .messages-sidebar{display:none}.messages-layout.show-chat .messages-content{display:flex}.messages-layout.show-chat .mobile-back-btn{display:inline-flex}}:root{--max: 1140px;--space-1: 8px;--space-2: 12px;--space-3: 16px;--space-4: 20px;--space-5: 28px;--space-6: 40px;--space-7: 56px;--brand: #0A8059;--brand-dark: #065f46;--brand-light: #4CAF50;--brand-50: #DFF7E5;--brand-100: #DFF7E5;--accent: #4CAF50;--ink: #0f172a;--ink-light: #1e293b;--muted: #313c4d;--muted-light: #94a3b8;--bg: #F7F9F9;--bg-light: #F7F9F9;--panel: #ffffff;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--ring: 0 10px 30px rgba(16, 185, 129, .15)}body{background:#fff;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{display:block!important;place-items:initial!important}.container{width:100%;max-width:var(--max);margin-inline:auto;padding-inline:24px}.lm-header{position:sticky;top:0;background:#fffffffa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 3px #0000000d,0 4px 12px #00000008;z-index:20;border-bottom:1px solid rgba(226,232,240,.6)}.lm-header .container{display:flex;justify-content:center;align-items:center;position:relative;padding:20px 24px}.lm-header-inner{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:var(--max)}.lm-brand{display:flex;align-items:center;gap:12px;cursor:pointer;transition:opacity .2s ease}.lm-brand:hover{opacity:.8}.lm-logo{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff8c00,#ff6b00);color:#fff;border-radius:12px;width:40px;height:40px;box-shadow:0 4px 12px #ff8c004d;transition:transform .2s ease,box-shadow .2s ease}.lm-logo:hover{transform:scale(1.05);box-shadow:0 6px 16px #ff8c0066}.lm-logo svg{width:20px;height:20px}.lm-brand>span:last-child{font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);font-size:18px;background:linear-gradient(135deg,var(--brand) 0%,#065f46 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lm-signin-right{position:absolute;right:24px;top:50%;transform:translateY(-50%);color:var(--brand);font-weight:600;text-decoration:none;padding:10px 20px;border-radius:10px;transition:all .2s ease;font-size:15px;border:1.5px solid transparent}.lm-signin-right:hover{background:var(--brand-50);color:var(--brand-dark);border-color:var(--brand-100)}.lm-signin-right:focus{outline:2px solid var(--brand);outline-offset:2px}.lm-hero{padding:clamp(64px,10vw,120px) 0 clamp(80px,12vw,120px);background:#fff}.lm-hero .container{text-align:center}.lm-badge{display:inline-block;margin-inline:auto;background:var(--brand-50);color:var(--brand-dark);border-radius:999px;padding:8px 16px;font-weight:600;font-size:14px;box-shadow:var(--shadow-sm);margin-bottom:24px}.lm-title{margin:0 0 20px;line-height:1.1}.lm-title .t1{font-size:clamp(40px,7vw,72px);font-weight:800;color:var(--ink);letter-spacing:-.02em}.lm-title .t2{font-size:clamp(36px,6.5vw,64px);font-weight:800;color:var(--brand);letter-spacing:-.02em}.lm-sub{color:var(--muted);max-width:740px;margin:0 auto 50px;font-size:clamp(16px,2vw,18px);line-height:1.6}.lm-actions{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}.btn{border-radius:12px;padding:14px 28px;font-weight:600;font-size:16px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s ease;min-width:180px;height:48px;box-sizing:border-box;position:relative;white-space:nowrap}.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{background:var(--brand-dark);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-primary:focus{outline:3px solid var(--brand-100);outline-offset:2px}.btn-ghost{background:#fff;color:var(--brand);border:2px solid var(--brand);box-shadow:var(--shadow-sm)}.btn-ghost:hover{background:#f8faf9;border-color:var(--brand);box-shadow:var(--shadow-sm)}.btn-ghost:active{background:#f1f5f9}.btn-ghost:focus{outline:3px solid var(--brand-100);outline-offset:2px}.lm-section{padding:clamp(64px,8vw,96px) 0}.lm-section .container{text-align:center}.lm-section-badge{display:inline-block;margin-inline:auto;margin-bottom:16px;background:var(--brand-50);color:var(--brand-dark);padding:8px 16px;border-radius:999px;font-weight:600;font-size:14px;box-shadow:var(--shadow-sm)}.lm-h2{font-size:clamp(32px,4.5vw,48px);font-weight:800;margin:0 0 12px;color:var(--ink);letter-spacing:-.01em}.lm-section-sub{color:var(--muted);max-width:640px;margin:0 auto 40px;font-size:18px;line-height:1.6}.lm-grid{margin-top:24px;display:grid;gap:24px;grid-template-columns:repeat(3,minmax(0,1fr));text-align:initial}.lm-grid.half{grid-template-columns:repeat(2,minmax(0,1fr))}.lm-grid-features{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:var(--panel);border-radius:16px;padding:32px 24px;box-shadow:var(--shadow-md);text-align:left;border:1px solid rgba(226,232,240,.8);transition:all .2s ease}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--brand-50);color:var(--brand-dark);margin-bottom:16px;font-size:24px;line-height:1}.card-icon svg{width:24px;height:24px;flex-shrink:0}.card h3{margin:0 0 12px;font-size:20px;font-weight:800;color:var(--ink);letter-spacing:-.01em}.card p{color:var(--muted);line-height:1.6;margin:0}.lm-footer{padding:64px 0 48px;background:linear-gradient(180deg,#fff,#f8faf9);border-top:1px solid rgba(226,232,240,.8)}.lm-footer .container{text-align:center}.lm-footer-content{display:flex;flex-direction:column;align-items:center;gap:24px}.lm-footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:8px}.lm-footer-logo{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff8c00,#ff6b00);color:#fff;border-radius:10px;width:36px;height:36px;box-shadow:0 4px 12px #ff8c0040}.lm-footer-logo svg{width:18px;height:18px}.lm-footer-brand-text{font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);font-size:16px;background:linear-gradient(135deg,var(--brand) 0%,#065f46 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lm-footer-tagline{color:var(--ink);font-size:18px;font-weight:600;margin-bottom:8px}.lm-footer-features{color:var(--muted);font-size:14px;font-weight:400;margin-bottom:16px;line-height:1.8}.lm-footer-copyright{color:var(--muted);font-size:14px;padding-top:24px;border-top:1px solid rgba(226,232,240,.6);width:100%;max-width:600px;margin:0 auto}@media(max-width:1200px){.lm-grid-features{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:900px){.lm-grid,.lm-grid-features{grid-template-columns:repeat(2,minmax(0,1fr))}.why-grid{grid-template-columns:1fr}.progress-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.lm-grid,.lm-grid.half,.lm-grid-features,.progress-grid{grid-template-columns:1fr}.lm-actions{flex-direction:column;width:100%}.btn{width:100%;max-width:320px}.lm-hero{padding:clamp(48px,8vw,80px) 0 clamp(60px,10vw,80px)}}.lm-section-alt{background:var(--bg-light)}.lm-section.progress{background:#fff;padding:clamp(64px,8vw,96px) 0}.progress-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card-feature{text-align:center;padding:24px 20px}.card-feature .card-icon{margin:0 auto 12px}.card-feature h3{font-size:16px;margin:0}.why-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.card-why{padding:28px 24px}.card-mode{padding:32px 24px}.lm-cta{background:linear-gradient(180deg,var(--bg) 0%,#ffffff 100%);padding:clamp(80px,10vw,120px) 0}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#ef781e;text-decoration:inherit}a:hover{color:#d45f0a}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#ef781e}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#d45f0a}button{background-color:#f9f9f9}}
