@keyframes slideIn{0%{opacity:0;transform:translate(100%)}60%{opacity:1;transform:translate(0)}80%{opacity:1;transform:translate(-15%)}to{opacity:1;transform:translate(0)}}.chatbot-button{cursor:pointer;z-index:100;transition:opacity .5s linear;animation:.6s ease-out forwards slideIn;display:flex;position:fixed;bottom:7em;right:2em}.chatbot-button__image{background-image:var(--tangerine-ai-bot);background-position:50%;background-repeat:no-repeat;background-size:cover;width:100px;height:100px}.chatbot-button:focus{outline:none}.chat-message{margin-bottom:10px;display:block;position:relative}.chat-bubble{gap:8px;margin-bottom:0;display:flex}.chat-bubble__avatar{background-color:transparent;background-image:var(--tangerine-ai-bot);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:0%;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:32px;height:32px;margin-bottom:0;display:flex;overflow:hidden}.chat-bubble__avatar--error{background-image:var(--tangerine-ai-bot-error)}.chat-bubble__content{flex-direction:column;flex:1;align-items:flex-start;gap:8px;display:flex}.chat-bubble__message-group{flex-direction:column;align-items:flex-start;width:100%;display:flex}.chat-bubble__message{word-wrap:break-word;color:#333;border:1px solid #e0e0e0;border-radius:8px;flex:1;font-size:16px;line-height:24px}.chat-bubble__message-content{padding:8px}.chat-bubble__message .markdown-container p{margin-bottom:.5rem}.chat-bubble__message .markdown-container p:last-child{margin-bottom:0}.chat-bubble__message .chat-d3-card{width:100%}.chat-bubble__message .chat-d3-card:first-child{margin-top:0}.chat-bubble__message .chat-d3-card:last-child{margin-bottom:0}.chat-bubble__image{margin-bottom:8px;padding:0 8px}.chat-bubble__image img{cursor:pointer;border-radius:8px;max-width:100%;max-height:300px;display:block}.chat-bubble__attachments{flex-direction:column;gap:8px;display:flex}.chat-bubble__attachments .chat-bubble__image{margin-bottom:0}.chat-bubble--bot .chat-bubble__content,.chat-bubble--bot .chat-bubble__message-group{width:100%}.chat-bubble--bot .chat-bubble__message{background-color:#fff;border-radius:8px 8px 8px 0;width:100%}.chat-bubble--user{flex-direction:row-reverse}.chat-bubble--user .chat-bubble__content{flex-direction:column;align-items:flex-end;display:flex}.chat-bubble--user .chat-bubble__message-group{align-self:flex-end;width:auto;max-width:80%}.chat-bubble--user .chat-bubble__message{background-color:var(--color-tangerine-ai-lighter,#d068d0);border:1px solid var(--color-tangerine-ai-light,#f0c0f0);color:#333;border-radius:8px 8px 0;width:100%}.chat-bubble--just-posted .chat-bubble__message{border-style:solid;border-width:1px;border-image:linear-gradient(111.12deg,var(--color-tangerine-ai,#bc3ebc)12.58%,var(--color-tangerine-ai-dark,#741571)100%)1}.chat-bubble__tool-indicators{flex-direction:column;gap:8px;width:100%;display:flex}.chat-message__bubble--error .chat-bubble__message{background:#fef0ef;border:1px solid #e04949}.chat-message--streaming .chat-bubble__content .typing-indicator{background-color:#fff;border:1px solid #f2f2f2;border-radius:8px 8px 8px 0;width:100%;padding:12px 16px}.chat-message__actions{align-items:center;gap:8px;margin-top:4px;margin-left:40px;display:flex}.chat-message__audio-button--loading{opacity:.6;cursor:wait}.chat-message--highlighted .chat-bubble--user .chat-bubble__message{border-color:#e04949}.chat-message__flag-button{transition:all .2s}.chat-message__flag-button--flagged{opacity:.7;cursor:default}.chat-message__flag-button--flagged:hover{opacity:.7}.analytics-filter-bar{align-items:center;gap:16px;display:flex}.analytics-filter-bar__filter{min-width:200px}.student-xray-drawer__header{border-bottom:1px solid #f2f2f2;justify-content:space-between;align-items:center;padding:8px;display:flex}.student-xray-drawer__student-info{align-items:center;gap:8px;display:flex}.student-xray-drawer__student-text{flex-direction:column;display:flex}.student-xray-drawer__student-name{font-family:var(--font-first-semi);color:#333;font-size:16px;font-weight:600;line-height:26px}.student-xray-drawer__student-class{font-family:var(--font-second);color:#767676;font-size:14px;font-weight:500;line-height:20px}.student-xray-drawer__close-btn{cursor:pointer;color:#767676;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex}.student-xray-drawer__close-btn:hover{color:#333}.student-xray-drawer__body{flex-direction:column;gap:24px;padding:8px 16px;display:flex;overflow-y:auto}.student-xray-drawer__stats{gap:8px;display:flex}.student-xray-drawer__stat-card{border:1px solid #e0e0e0;border-radius:8px;flex:1;padding:8px 16px}.student-xray-drawer__stat-label{font-family:var(--font-second);color:#4e4e4e;font-size:14px;font-weight:500;line-height:20px}.student-xray-drawer__stat-value-row{align-items:baseline;gap:4px;display:flex}.student-xray-drawer__stat-value{font-family:var(--font-second);color:#333;font-size:18px;font-weight:700;line-height:26px}.student-xray-drawer__stat-unit{font-family:var(--font-second);color:#767676;font-size:14px;font-weight:500;line-height:20px}.student-xray-drawer__quality-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.student-xray-drawer__quality-label{font-family:var(--font-second);color:#333;font-size:16px;font-weight:500;line-height:24px}.student-xray-drawer__quality-percentage{font-family:var(--font-second);color:#6b0a6b;font-size:14px;font-weight:700;line-height:17px}.student-xray-drawer__quality-bar{background-color:#f2f2f2;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.student-xray-drawer__quality-bar-fill{background-color:#e047e0;border-radius:4px;height:100%}.student-xray-drawer__quality-description{font-family:var(--font-second);color:#4e4e4e;font-size:14px;font-weight:500;line-height:20px}.student-xray-drawer__intent-section-title{font-family:var(--font-second);color:#333;margin-bottom:8px;font-size:16px;font-weight:500;line-height:24px}.student-xray-drawer__intent-list{flex-direction:column;gap:16px;display:flex}.student-xray-drawer__intent-row{flex-direction:column;gap:8px;display:flex}.student-xray-drawer__intent-header{justify-content:space-between;align-items:center;display:flex}.student-xray-drawer__intent-label{font-family:var(--font-second);color:#4e4e4e;font-size:14px;font-weight:500;line-height:20px}.student-xray-drawer__intent-percentage{font-family:var(--font-second);font-size:14px;font-weight:700;line-height:17px}.student-xray-drawer__intent-bar{background-color:#f2f2f2;border-radius:4px;height:8px;overflow:hidden}.student-xray-drawer__intent-bar-fill{border-radius:4px;height:100%}.student-xray-drawer__intent-row--color-1 .student-xray-drawer__intent-percentage{color:#6b0a6b}.student-xray-drawer__intent-row--color-1 .student-xray-drawer__intent-bar-fill{background-color:#e047e0}.student-xray-drawer__intent-row--color-2 .student-xray-drawer__intent-percentage{color:#70022e}.student-xray-drawer__intent-row--color-2 .student-xray-drawer__intent-bar-fill{background-color:#e3366f}.student-xray-drawer__intent-row--color-3 .student-xray-drawer__intent-percentage{color:#662014}.student-xray-drawer__intent-row--color-3 .student-xray-drawer__intent-bar-fill{background-color:#ff7450}.student-xray-drawer__intent-row--color-4 .student-xray-drawer__intent-percentage{color:#664306}.student-xray-drawer__intent-row--color-4 .student-xray-drawer__intent-bar-fill{background-color:#ffb233}.student-xray-drawer__intent-row--color-5 .student-xray-drawer__intent-percentage{color:#305001}.student-xray-drawer__intent-row--color-5 .student-xray-drawer__intent-bar-fill{background-color:#91d432}.student-xray-drawer__intent-row--color-6 .student-xray-drawer__intent-percentage{color:#05490b}.student-xray-drawer__intent-row--color-6 .student-xray-drawer__intent-bar-fill{background-color:#36c03c}.student-xray-drawer__intent-row--color-7 .student-xray-drawer__intent-percentage{color:#014d5c}.student-xray-drawer__intent-row--color-7 .student-xray-drawer__intent-bar-fill{background-color:#3ce4f1}.student-xray-drawer__intent-row--color-8 .student-xray-drawer__intent-percentage{color:#0a3366}.student-xray-drawer__intent-row--color-8 .student-xray-drawer__intent-bar-fill{background-color:#4eabff}.distribution-bar,.distribution-bar__container{width:100%;position:relative}.distribution-bar__container--with-labels-above{margin-top:40px}.distribution-bar__segments-wrapper{width:100%;height:24px;display:flex}.distribution-bar__segment-wrapper{flex-direction:column;align-items:center;height:24px;display:flex;position:relative}.distribution-bar__segment-wrapper--with-border:after{content:"";border-right:2px dashed #0095a2;width:1px;position:absolute;top:-10px;bottom:-10px;right:0}.distribution-bar__label-container{z-index:2;flex-direction:column;align-items:center;display:flex;position:absolute;top:-40px;left:100%;transform:translate(-50%)}.distribution-bar__label-container--last{transform:translate(-100%)}.distribution-bar__percentage-value{font-size:18px;font-weight:700;font-family:var(--font-first);color:#4e4e4e;white-space:nowrap;line-height:28px}.distribution-bar__segment{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.distribution-bar__segment--mastered{background-color:#0095a2}.distribution-bar__segment--in-progress{background-color:#00b4c5}.distribution-bar__segment--not-started{background-color:#d4fbff}.distribution-bar__segment-label{font-size:12px;font-weight:600;font-family:var(--font-first);color:#333;white-space:nowrap;z-index:1}.distribution-bar__segment--first{border-radius:8px 0 0 8px}.distribution-bar__segment--last{border-radius:0 8px 8px 0}.distribution-bar__segment--only{border-radius:8px}.distribution-bar__segment-wrapper:first-child .distribution-bar__segment{border-radius:8px 0 0 8px}.distribution-bar__segment-wrapper:last-child .distribution-bar__segment{border-radius:0 8px 8px 0}.distribution-bar__segment-wrapper:only-child .distribution-bar__segment{border-radius:8px}.distribution-bar__legend{gap:16px;margin-top:16px;display:flex}.distribution-bar__legend-item{align-items:center;gap:8px;display:flex}.distribution-bar__legend-color{border-radius:2px;flex-shrink:0;width:28px;height:12px}.distribution-bar__legend-text{color:#4e4e4e;font-family:Lato Regular,sans-serif;font-size:14px;font-weight:500;line-height:1}.distribution-bar__labels{display:none}.distribution-bar--small .distribution-bar__container--with-labels-above{margin-top:26px}.distribution-bar--small .distribution-bar__segments-wrapper,.distribution-bar--small .distribution-bar__segment-wrapper{height:8px}.distribution-bar--small .distribution-bar__label-container{top:-26px}.distribution-bar--small .distribution-bar__segment--first{border-radius:4px 0 0 4px}.distribution-bar--small .distribution-bar__segment--last{border-radius:0 4px 4px 0}.distribution-bar--small .distribution-bar__segment--only{border-radius:4px}.distribution-bar--small .distribution-bar__percentage-value{font-family:var(--font-first);color:#4e4e4e;text-align:right;font-size:14px;font-weight:500;line-height:20px}.teacher-analytics-view__loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:400px;display:flex}.teacher-analytics-view__loading p{color:#767676;font-size:14px}.teacher-analytics-view__error{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:400px;display:flex}.teacher-analytics-view__error p{color:#dc3545;max-width:500px;font-size:14px}.teacher-analytics-view__header-container{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.teacher-analytics-view__header-container .teacher-analytics-view__class-selector{min-width:200px;max-width:300px;margin-left:auto}.teacher-analytics-view__subject-selector{min-width:200px;max-width:300px}.teacher-analytics-view__units-grid{flex-direction:column;gap:16px;width:100%;display:flex}.teacher-analytics-view__sections-container{flex-direction:column;gap:16px;display:flex}.teacher-analytics-view__section-separator{border-bottom:1px solid #eee4dc;margin:16px 0}.teacher-analytics-view__recommendations{gap:var(--spacing-lg);flex-direction:column;width:100%;display:flex}.teacher-analytics-view__section{display:block}.teacher-analytics-view__section-title{color:#333;font-size:22px;font-weight:700;font-family:var(--font-first);margin:0 0 24px}.teacher-analytics-view__legend{justify-content:flex-end;gap:24px;margin-top:16px;display:flex}.teacher-analytics-view__legend-item{align-items:center;gap:8px;display:flex}.teacher-analytics-view__legend-color{border-radius:4px;flex-shrink:0;width:16px;height:16px}.teacher-analytics-view__legend-color--mastered{background-color:#0095a2}.teacher-analytics-view__legend-color--in-progress{background-color:#00b4c5}.teacher-analytics-view__legend-color--not-started{background-color:#d4fbff}.teacher-analytics-view__legend-text{font-size:14px;font-weight:500;font-family:var(--font-second);color:#4e4e4e;line-height:1}.student-recommendations{border:2px solid var(--color-tangerine-ai,#bc3ebc);background:#fff;border-radius:8px;flex-direction:column;gap:16px;width:100%;padding:16px 24px;display:flex;position:relative}.student-recommendations--loading{justify-content:center;align-items:center;min-height:200px;display:flex}.student-recommendations__loader{color:#4e4e4e;font-size:16px}.student-recommendations__header{justify-content:space-between;align-items:center;gap:16px;display:flex}.student-recommendations__header-left{align-items:center;gap:16px;display:flex}.student-recommendations__avatar{background-image:var(--tangerine-ai-bot-happy);background-position:50%;background-repeat:no-repeat;background-size:cover;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.student-recommendations__header-content{flex:1}.student-recommendations__title{color:#333;font-family:var(--font-first);font-size:22px;font-style:normal;font-weight:500;line-height:32px}.student-recommendations__subtitle{color:#4f4f4f;font-family:var(--font-second);font-size:16px;font-style:normal;font-weight:500;line-height:24px}.student-recommendations__cards{gap:12px;padding-top:8px;padding-bottom:24px;display:flex;overflow-x:auto}.student-recommendations__cards::-webkit-scrollbar{height:6px}.student-recommendations__cards::-webkit-scrollbar-track{background:#f2f2f2;border-radius:3px}.student-recommendations__cards::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px}.student-recommendations__card{cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:16px;flex-direction:column;flex-shrink:0;justify-content:space-between;width:362px;min-height:136px;padding:8px 8px 0;transition:all .1s ease-in;display:flex;position:relative;box-shadow:0 2px #f8f8f8}.student-recommendations__card:hover{border:1px solid #bdbdbd;width:460px;box-shadow:0 2px 3px #ececec}.student-recommendations__card:focus{outline:none}.student-recommendations__card:focus-visible{background-image:linear-gradient(#fff,#fff),linear-gradient(111.12deg,#e14de3 12.58%,#8c2a89 100%);background-origin:border-box;background-clip:padding-box,border-box;border:1px solid transparent;width:460px;box-shadow:0 2px 3px #ececec}.student-recommendations__card:active{background-image:none!important;border:1px solid #bdbdbd!important;box-shadow:inset 0 3px rgba(224,224,224,.7)!important}.student-recommendations__card:hover:focus-visible{width:460px}.student-recommendations__card-body{flex-direction:column;flex:1;display:flex}.student-recommendations__card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.student-recommendations__card-header--left{flex-direction:row;flex:1;align-items:flex-start;gap:8px;min-width:0;display:flex}.student-recommendations__card-icon{flex-shrink:0;justify-content:center;align-items:center;font-size:24px;display:flex}.student-recommendations__card-icon img{width:100%;max-width:50px}.student-recommendations__card-content{flex:1;min-width:0;overflow:hidden}.student-recommendations__card-title{color:#333;font-family:var(--font-first);width:100%;margin:0;font-size:16px;font-style:normal;font-weight:500;line-height:26px;overflow:hidden}.student-recommendations__card-title .text-html{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.student-recommendations__card-subtitle{color:#4e4e4e;font-family:var(--font-second);width:100%;margin:0;font-size:16px;font-style:normal;font-weight:500;line-height:24px}.student-recommendations__card-subtitle .text-html>:first-child{white-space:nowrap;text-overflow:ellipsis;display:block;overflow:hidden}.student-recommendations__card:hover .student-recommendations__card-subtitle .text-html>:first-child{white-space:normal;-webkit-line-clamp:2;line-clamp:2;box-orient:vertical;text-overflow:ellipsis;-webkit-box-orient:vertical;max-height:48px;display:-webkit-box;overflow:hidden}.student-recommendations__card-progress{flex-shrink:0;justify-content:center;align-items:center;display:flex}.student-recommendations__card-check-icon{color:#fff;justify-content:center;align-items:center;width:14px;height:14px;display:flex}.student-recommendations__card-check-icon .icon{color:#fff;width:100%;height:100%}.student-recommendations__card-progress-bar{background-color:#f2f2f2;height:2px;margin:0 -8px;position:relative;overflow:hidden}.student-recommendations__card-progress-bar-fill{background-color:#41d158;height:100%;transition:width .3s}.student-recommendations__card-footer{justify-content:space-between;align-items:center;gap:8px;padding:8px 0;display:flex}.student-recommendations__activities,.student-recommendations__session-status{font-size:16px;font-weight:500;font-family:var(--font-first);background:var(--color-tangerine-ai-gradient,linear-gradient(111deg,#e14de3 12.58%,#8c2a89 100%));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;align-items:center;height:20px;display:inline-flex}@media (max-width:768px){.student-recommendations{padding:16px}.student-recommendations__title{font-size:20px}.student-recommendations__subtitle{font-size:14px}}@media (max-width:480px){.student-recommendations{margin:16px 0}.student-recommendations__header{gap:12px}.student-recommendations__avatar-icon{width:40px;height:40px;font-size:20px}}