:root{--color-primary: #4A4DC9;--color-primary-hover: #3d40a8;--color-primary-pressed: #32358a;--color-highlight: #FF7212;--color-highlight-hover: #FC9145;--color-highlight-bg: #FFF3E4;--color-accent-purple: #533086;--color-accent-purple-light: #C1C1EA;--color-text: #4E4E4E;--color-text-muted: #6B6B6B;--color-border: #CACACA;--color-border-light: #EBEBEB;--color-bg: #F5F5F5;--color-bg-card: #ffffff;--color-disabled: #CACACA;--color-disabled-bg: #EBEBEB;--gradient-primary: linear-gradient(135deg, #4A4DC9 0%, #533086 100%);--gradient-primary-soft: linear-gradient(135deg, rgba(74, 77, 201, .12) 0%, rgba(83, 48, 134, .08) 100%);--gradient-hero: linear-gradient(160deg, #f8f7ff 0%, #f0eeff 40%, #fff8f2 100%);--gradient-accent: linear-gradient(135deg, #FF7212 0%, #FC9145 100%);--gradient-card: linear-gradient(180deg, #ffffff 0%, #fdfcff 100%);--gradient-header: linear-gradient(90deg, #ffffff 0%, #fafaff 50%, #fffbf7 100%);--shadow-glow-primary: 0 8px 32px rgba(74, 77, 201, .2);--shadow-glow-highlight: 0 8px 32px rgba(255, 114, 18, .2);--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1);font-family:Poppins,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes progressFill{0%{width:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes pulse-soft{0%,to{opacity:1;box-shadow:0 0 #4a4dc940}50%{opacity:.95;box-shadow:0 0 0 8px #4a4dc900}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.btn-contained{padding:12px 24px;min-height:40px;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .3s}.btn-contained:hover:not(:disabled){box-shadow:var(--shadow-glow-primary);transform:translateY(-1px)}.btn-contained:active:not(:disabled){transform:scale(.98)}.btn-contained:disabled{background:var(--color-disabled);cursor:not-allowed;opacity:.8}.btn-highlight{background:var(--gradient-accent);color:#fff}.btn-highlight:hover:not(:disabled){box-shadow:var(--shadow-glow-highlight)}.btn-outlined{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outlined:hover:not(:disabled){background:var(--color-accent-purple-light);color:var(--color-accent-purple)}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-40%;right:-20%;width:70%;height:80%;background:radial-gradient(ellipse at center,rgba(74,77,201,.2) 0%,rgba(83,48,134,.12) 40%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 8s ease-in-out infinite}.login-page:after{content:"";position:absolute;bottom:-30%;left:-15%;width:55%;height:65%;background:radial-gradient(ellipse at center,rgba(255,114,18,.15) 0%,rgba(252,145,69,.08) 40%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 10s ease-in-out infinite reverse}.login-card{position:relative;z-index:1;width:100%;max-width:440px;padding:3rem 2.5rem;background:var(--gradient-card);border-radius:20px;border:1px solid var(--color-border-light);box-shadow:0 4px 24px #4a4dc914,0 12px 48px #0000000f;animation:scaleIn .5s var(--transition-smooth) both;transition:box-shadow .4s,transform .3s}.login-card:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.login-title{margin:0 0 .25rem;font-size:1.875rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .1s both}.login-subtitle{margin:0 0 2rem;color:var(--color-text-muted);text-align:center;font-size:.9375rem;font-weight:500;animation:fadeInUp .5s var(--transition-smooth) .15s both}.login-form{display:flex;flex-direction:column;gap:1.375rem;animation:fadeInUp .5s var(--transition-smooth) .2s both}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.form-group input{padding:14px 16px;border:2px solid var(--color-border-light);border-radius:10px;background:var(--color-bg-card);color:var(--color-text);font-family:"Poppins",inherit;font-size:1rem;transition:border-color .3s,box-shadow .3s,transform .2s}.form-group input::placeholder{color:var(--color-border)}.form-group input:hover{border-color:var(--color-accent-purple-light)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4a4dc933;transform:translateY(-1px)}.login-error{margin:0;font-size:.875rem;font-weight:500;color:var(--color-highlight);animation:fadeIn .3s ease}.login-button{margin-top:.5rem;padding:14px 24px;min-height:48px;background:var(--gradient-primary);background-size:200% 200%;color:#fff;border:none;border-radius:10px;font-family:"Poppins",inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:box-shadow .3s,transform .2s}.login-button:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.login-button:active{transform:scale(.98)}.home-page{min-height:100vh;background:var(--gradient-hero);animation:fadeIn .4s ease}.home-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 2rem 1rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.header-left{display:flex;align-items:center;gap:.75rem}.logo-link{text-decoration:none;color:inherit;transition:transform .2s}.logo-link:hover{transform:scale(1.02)}.logo-link:hover h1{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-header h1{margin:0;font-size:1.375rem;font-weight:700;color:var(--color-primary);letter-spacing:-.02em;transition:color .2s}.header-badge{font-size:.75rem;font-weight:600;color:var(--color-text-muted);background:var(--gradient-primary-soft);padding:.25rem .625rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em;border:1px solid rgba(74,77,201,.15)}.header-right{display:flex;align-items:center;gap:1rem}.user-pill{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem .375rem .375rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:999px;text-decoration:none;color:var(--color-text);font-size:.875rem;font-weight:600;transition:border-color .3s,box-shadow .3s,transform .2s}.user-pill:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #4a4dc926;transform:translateY(-1px)}.user-pill-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}.user-pill:hover .user-pill-avatar{transform:scale(1.08)}.user-pill-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.logout-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.home-main{max-width:960px;margin:0 auto;padding:2rem 2rem 3rem}.home-hero{margin-bottom:1.75rem;animation:fadeInUp .5s var(--transition-smooth) .1s both}.home-main h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.welcome-text{margin:0 0 1.25rem;font-size:.9375rem;color:var(--color-text-muted)}.welcome-text strong{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}.progress-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:1rem 1.25rem;background:var(--gradient-card);border-radius:12px;border:1px solid var(--color-border-light);box-shadow:0 4px 16px #4a4dc90f;transition:box-shadow .3s}.progress-strip:hover{box-shadow:0 6px 20px #4a4dc91a}.progress-label{font-size:.8125rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.progress-bar-wrap{flex:1;min-width:120px;height:10px;background:var(--color-border-light);border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:var(--gradient-primary);border-radius:999px;transition:width .5s var(--transition-bounce)}.progress-count{font-size:.875rem;font-weight:600;color:var(--color-primary)}.dropdowns-wrapper{background:var(--gradient-card);border-radius:16px;border:1px solid var(--color-border-light);padding:2rem;margin-bottom:1.5rem;box-shadow:0 4px 20px #4a4dc914;animation:fadeInUp .5s var(--transition-smooth) .2s both;transition:box-shadow .3s,transform .2s}.dropdowns-wrapper:hover{box-shadow:0 8px 28px #4a4dc91f}.dropdowns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.dropdown-group{display:flex;flex-direction:column;gap:.5rem;transition:transform .3s,opacity .3s;animation:fadeInUp .4s var(--transition-smooth) both}.dropdown-group:nth-child(1){animation-delay:.25s}.dropdown-group:nth-child(2){animation-delay:.3s}.dropdown-group:nth-child(3){animation-delay:.35s}.dropdown-group:nth-child(4){animation-delay:.4s}.dropdown-group:nth-child(5){animation-delay:.45s}.dropdown-group:hover{transform:translateY(-2px)}.dropdown-group--selected select{border-color:var(--color-primary);background:var(--gradient-primary-soft);box-shadow:0 0 0 1px #4a4dc933}.dropdown-group label{font-size:.875rem;font-weight:600;color:var(--color-text)}.dropdown-group select{padding:12px 16px;border:2px solid var(--color-border-light);border-radius:10px;background:var(--color-bg-card);color:var(--color-text);font-family:"Poppins",inherit;font-size:.9375rem;cursor:pointer;transition:border-color .3s,box-shadow .3s,background .3s,transform .2s}.dropdown-group select:hover{border-color:var(--color-accent-purple-light)}.dropdown-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4a4dc933;transform:translateY(-1px)}.dropdown-group select option{background:var(--color-bg-card);color:var(--color-text)}.validate-actions{display:flex;align-items:center;gap:1rem;animation:fadeInUp .5s var(--transition-smooth) .35s both}.validate-btn{padding:14px 28px;min-height:48px;background:var(--color-disabled);color:var(--color-text-muted);border:none;border-radius:10px;font-family:"Poppins",inherit;font-size:.9375rem;font-weight:600;cursor:not-allowed;transition:all .4s var(--transition-smooth)}.validate-btn--active,.validate-btn:not(:disabled):hover{background:var(--gradient-primary);color:#fff;cursor:pointer;box-shadow:var(--shadow-glow-primary);transform:translateY(-2px)}.validate-btn--active{animation:pulse-soft 2.5s ease-in-out infinite}.validate-btn--active:hover{box-shadow:0 12px 40px #4a4dc959;transform:translateY(-3px)}.validate-btn:disabled{opacity:1}.validate-btn:active:not(:disabled){transform:scale(.98)}.learning-plan-view{padding:0;min-height:0;display:flex;flex-direction:column;overflow:visible}.learning-plan-view--loading,.learning-plan-view--error{align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.9375rem}.learning-plan-view--error{color:var(--color-highlight)}.lp-hero{background:var(--gradient-primary);color:#fff;padding:1rem 1.25rem;border-radius:12px;margin-bottom:1.25rem;box-shadow:0 4px 16px #4a4dc940;transition:box-shadow .3s ease,transform .3s ease;animation:lp-hero-in .5s ease-out}.lp-hero:hover{box-shadow:0 8px 28px #4a4dc959;transform:translateY(-2px)}@keyframes lp-hero-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.lp-chapter-title{margin:0;font-size:1.125rem;font-weight:700;letter-spacing:-.02em;line-height:1.3}.lp-content{flex:1;min-height:0;overflow:visible;padding-right:0}.lp-module{background:var(--gradient-card);border:1px solid var(--color-border-light);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 2px 12px #4a4dc90f;transition:box-shadow .3s ease,transform .3s ease,border-color .3s ease;animation:lp-module-in .4s ease-out backwards}.lp-module:nth-child(1){animation-delay:.05s}.lp-module:nth-child(2){animation-delay:.1s}.lp-module:nth-child(3){animation-delay:.15s}.lp-module:nth-child(4){animation-delay:.2s}.lp-module:nth-child(5){animation-delay:.25s}.lp-module:nth-child(n+6){animation-delay:.3s}.lp-module:hover{box-shadow:0 8px 28px #4a4dc924;transform:translateY(-3px);border-color:#4a4dc933}@keyframes lp-module-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.lp-module-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border-light)}.lp-module-badge{flex-shrink:0;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;padding:.35rem .6rem;border-radius:8px;transition:transform .25s ease,box-shadow .25s ease}.lp-module:hover .lp-module-badge{transform:scale(1.08);box-shadow:0 2px 12px #4a4dc966}.lp-module-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.lp-segment{margin-bottom:1.25rem}.lp-segment:last-child{margin-bottom:0}.lp-segment-title{margin:0 0 .75rem;font-size:.9375rem;font-weight:600;color:var(--color-accent-purple);display:flex;align-items:baseline;gap:.5rem;transition:color .25s ease,letter-spacing .25s ease}.lp-segment:hover .lp-segment-title{color:var(--color-primary);letter-spacing:.02em}.lp-segment-id{flex-shrink:0;font-size:.75rem;color:var(--color-primary);background:var(--gradient-primary-soft);padding:.2rem .45rem;border-radius:6px}.lp-topic{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem;transition:box-shadow .3s ease,transform .3s ease,border-color .3s ease,background .3s ease}.lp-topic:last-child{margin-bottom:0}.lp-topic--has-images{cursor:pointer}.lp-topic--has-images:hover{box-shadow:0 8px 24px #4a4dc92e;transform:translateY(-2px);border-color:#4a4dc959}.lp-topic--has-images:active{transform:translateY(0)}.lp-topic--focused{border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc940;background:linear-gradient(135deg,rgba(74,77,201,.08) 0%,var(--color-bg) 100%);animation:lp-topic-focused-pulse 2s ease-in-out infinite}@keyframes lp-topic-focused-pulse{0%,to{box-shadow:0 0 0 2px #4a4dc940}50%{box-shadow:0 0 0 3px #4a4dc959}}.lp-topic-title{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:var(--color-text);display:flex;align-items:baseline;gap:.5rem}.lp-topic-id{flex-shrink:0;font-size:.7rem;color:var(--color-text-muted);font-weight:500}.lp-block{margin-bottom:1rem}.lp-block:last-child{margin-bottom:0}.lp-block-label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:.4rem;transition:color .25s ease,letter-spacing .25s ease}.lp-block:hover .lp-block-label{letter-spacing:.08em}.lp-bullet-list{margin:0;padding-left:1.25rem;font-size:.8125rem;color:var(--color-text-muted);line-height:1.6}.lp-bullet-list li{margin-bottom:.25rem}.lp-objective-list{margin:0;padding-left:1.25rem;font-size:.8125rem;color:var(--color-text-muted);line-height:1.6}.lp-objective-item{margin-bottom:.75rem}.lp-objective-item:last-child{margin-bottom:0}.lp-objective-text{display:block;margin-bottom:.5rem}.lp-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:.75rem}.lp-figure{margin:0;background:var(--color-bg-card);border-radius:10px;overflow:hidden;border:1px solid var(--color-border-light);box-shadow:0 2px 8px #0000000f;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease}.lp-figure:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #4a4dc92e}.lp-figure .lp-image{transition:transform .5s ease}.lp-figure:hover .lp-image{transform:scale(1.06)}.lp-image{width:100%;height:auto;display:block;aspect-ratio:4 / 3;object-fit:cover}.lp-figcaption{padding:.5rem .75rem;font-size:.75rem;font-weight:600;color:var(--color-text);background:var(--gradient-primary-soft)}.lp-image-desc{margin:0;padding:.5rem .75rem;font-size:.7rem;color:var(--color-text-muted);line-height:1.4;border-top:1px solid var(--color-border-light)}.lp-image-wrap,.lp-carousel-image-wrap{position:relative;overflow:hidden;display:block}.lp-image-wrap--mark-mode{cursor:crosshair}.lp-image-wrap .lp-image,.lp-carousel-image-wrap .lp-carousel-image{display:block;width:100%;height:auto;vertical-align:top}.lp-markup-overlay{position:absolute;border:2px solid rgba(220,38,38,.9);background:#dc262633;pointer-events:none;display:flex;align-items:flex-end;padding:2px;box-sizing:border-box}.lp-markup-note{font-size:.6rem;line-height:1.2;color:#fff;background:#000000bf;padding:2px 4px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lp-markup-overlay--drawn{left:0;top:0;width:100%;height:100%;border:none;background:transparent;padding:0;flex-direction:column;align-items:stretch;justify-content:flex-end}.lp-markup-drawn-img{position:absolute;left:0;top:0;width:100%;height:100%;object-fit:fill;pointer-events:none}.lp-markup-overlay--drawn .lp-markup-note{position:relative;z-index:1;margin-top:auto}.lp-image-actions,.lp-carousel-image-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;padding:.4rem .5rem;border-top:1px solid var(--color-border-light);background:var(--color-bg)}.lp-img-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .5rem;font-size:.7rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;cursor:pointer;transition:color .2s,background .2s,border-color .2s}.lp-img-btn:hover{color:var(--color-text);border-color:var(--color-primary)}.lp-img-btn--like.lp-img-btn--active{color:#0d9488;background:#0d94881f;border-color:#0d9488}.lp-img-btn--dislike.lp-img-btn--active{color:#dc2626;background:#dc26261a;border-color:#dc2626}.lp-img-btn--mark.lp-img-btn--active{color:var(--color-primary);background:var(--gradient-primary-soft);border-color:var(--color-primary)}.lp-image-dislike-form{padding:.5rem .75rem;border-top:1px solid var(--color-border-light);background:var(--color-bg)}.lp-image-dislike-form--carousel{margin-top:.25rem}.lp-image-dislike-label{display:block;font-size:.7rem;font-weight:600;color:var(--color-text);margin-top:.35rem;margin-bottom:.2rem}.lp-image-dislike-label:first-child{margin-top:0}.lp-image-dislike-input{width:100%;padding:.4rem .5rem;font-size:.75rem;font-family:inherit;line-height:1.4;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;resize:vertical;box-sizing:border-box}.lp-image-dislike-input:focus{outline:none;border-color:var(--color-primary)}.lp-img-save-btn{display:inline-flex;align-items:center;gap:.25rem;margin-top:.5rem;padding:.35rem .65rem;font-size:.75rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:6px;cursor:pointer;transition:opacity .2s,transform .2s}.lp-img-save-btn:hover{opacity:.95;transform:scale(1.02)}.lp-carousel-slide{display:flex;flex-direction:column;align-items:center;gap:.25rem;min-width:0}.lp-carousel-image-wrap{width:100%;min-height:0;position:relative;border-radius:10px;overflow:hidden}.lp-carousel-image-wrap .lp-carousel-image{max-width:100%;max-height:60vh;width:auto;height:auto;object-fit:contain;display:block}.lp-table-wrap{overflow-x:auto}.lp-table{width:100%;max-width:280px;border-collapse:collapse;font-size:.8125rem;border-radius:8px;overflow:hidden;border:1px solid var(--color-border-light);box-shadow:0 2px 8px #0000000a;transition:box-shadow .3s ease}.lp-table-wrap:hover .lp-table{box-shadow:0 6px 20px #4a4dc91a}.lp-table tbody tr{transition:background .2s ease}.lp-table tbody tr:hover{background:#4a4dc914}.lp-table thead{background:var(--gradient-primary);color:#fff}.lp-table th{padding:.5rem .75rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.lp-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border-light);color:var(--color-text)}.lp-table tbody tr:last-child td{border-bottom:none}.lp-table tbody tr:nth-child(2n){background:#4a4dc90a}.lp-chunks{display:flex;flex-direction:column;gap:.75rem;overflow:visible}.lp-chunk{padding:.75rem 1rem;background:var(--color-bg-card);border-radius:8px;border-left:4px solid var(--color-primary);transition:box-shadow .35s ease,transform .35s ease,border-left-width .25s ease,background .25s ease;position:relative;overflow:hidden;transform-origin:left center;z-index:0}.lp-chunk:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .5s ease;pointer-events:none}.lp-chunk:hover{box-shadow:0 16px 40px #4a4dc938;transform:scale(1.08);border-left-width:6px;z-index:3}.lp-chunk:hover .lp-chunk-text{color:var(--color-text);font-size:.9375rem;line-height:1.65}.lp-chunk:hover .lp-block-label{font-size:.75rem}.lp-chunk--original{border-left-color:var(--color-border);background:var(--color-bg)}.lp-chunk--original:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent)}.lp-chunk--original:hover{box-shadow:0 16px 40px #00000024;transform:scale(1.08);border-left-width:6px;background:var(--color-bg-card)}.lp-chunk-text{margin:0;font-size:.8125rem;line-height:1.6;color:var(--color-text-muted);transition:color .3s ease,font-size .3s ease,line-height .3s ease}.lp-chunk-text strong{color:var(--color-text);font-weight:600}.lp-topic-actions{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.lp-action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8125rem;font-weight:600;color:var(--color-text-muted);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:8px;cursor:pointer;transition:color .2s,background .2s,border-color .2s,box-shadow .2s,transform .2s}.lp-action-btn:hover{color:var(--color-text);background:var(--color-bg);border-color:var(--color-primary);box-shadow:0 2px 8px #4a4dc91f;transform:scale(1.05)}.lp-action-btn:active{transform:scale(.98)}.lp-action-btn--like.lp-action-btn--active{color:#0d9488;background:#0d94881f;border-color:#0d9488}.lp-action-btn--dislike.lp-action-btn--active{color:#dc2626;background:#dc26261a;border-color:#dc2626}.lp-dislike-reason-wrap{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.lp-dislike-reason-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:.4rem}.lp-dislike-reason-input{width:100%;min-height:72px;padding:.6rem .75rem;font-size:.8125rem;font-family:inherit;line-height:1.5;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:8px;resize:vertical;transition:border-color .2s,box-shadow .2s}.lp-dislike-reason-input::placeholder{color:var(--color-text-muted)}.lp-dislike-reason-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc933}.lp-save-btn{display:inline-flex;align-items:center;gap:.4rem;margin-top:.6rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600;color:#fff;background:var(--gradient-primary);border:none;border-radius:8px;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s}.lp-save-btn:hover{opacity:.95;transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #4a4dc966}.lp-save-btn:active{transform:translateY(0) scale(.98)}.lp-image-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:lp-modal-fade-in .2s ease-out}@keyframes lp-modal-fade-in{0%{opacity:0}to{opacity:1}}.lp-image-modal{position:relative;background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #0003;max-width:90vw;max-height:90vh;width:100%;overflow:hidden;display:flex;flex-direction:column;animation:lp-modal-scale-in .25s ease-out}@keyframes lp-modal-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.lp-image-modal-close{position:absolute;top:.75rem;right:.75rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0003;color:#fff;border:none;border-radius:50%;cursor:pointer;z-index:2;transition:background .2s}.lp-image-modal-close:hover{background:#0006}.lp-image-modal-title{margin:0;padding:1rem 3rem .5rem 1.25rem;font-size:1rem;font-weight:700;color:var(--color-text);display:flex;align-items:baseline;gap:.5rem}.lp-image-modal-topic-id{flex-shrink:0;font-size:.75rem;font-weight:600;color:var(--color-primary);background:var(--gradient-primary-soft);padding:.25rem .5rem;border-radius:6px}.lp-carousel{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem 1rem;min-height:0}.lp-carousel-btn{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;border:none;border-radius:50%;cursor:pointer;transition:transform .2s,box-shadow .2s}.lp-carousel-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px #4a4dc966}.lp-carousel-slide{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:.5rem}.lp-carousel-image{max-width:100%;max-height:60vh;width:auto;height:auto;object-fit:contain;border-radius:10px;background:var(--color-bg)}.lp-carousel-caption{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-align:center}.lp-carousel-dots{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.75rem 1rem 1rem}.lp-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--color-border);cursor:pointer;padding:0;transition:background .2s,transform .2s}.lp-carousel-dot:hover,.lp-carousel-dot--active{background:var(--color-primary);transform:scale(1.2)}.lp-image-modal-empty{margin:0;padding:2rem 1.5rem;font-size:.9375rem;color:var(--color-text-muted);text-align:center}.lp-markarea-modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1001;padding:1.5rem;animation:lp-modal-fade-in .2s ease-out}.lp-markarea-modal{background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #00000040;max-width:90vw;max-height:90vh;width:100%;overflow:hidden;display:flex;flex-direction:column;animation:lp-modal-scale-in .25s ease-out}.lp-markarea-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--gradient-primary);color:#fff;flex-shrink:0}.lp-markarea-modal-title{margin:0;font-size:1rem;font-weight:700;letter-spacing:-.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 48px)}.lp-markarea-modal-close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s;flex-shrink:0}.lp-markarea-modal-close:hover{background:#ffffff59}.lp-markarea-modal-body{padding:1rem 1.25rem;overflow-y:auto;flex:1;min-height:0}.lp-markarea-image-container{position:relative;display:inline-block;max-width:100%;margin-bottom:.75rem;border-radius:10px;overflow:hidden;border:1px solid var(--color-border-light);background:var(--color-bg)}.lp-markarea-image{display:block;max-width:100%;max-height:55vh;width:auto;height:auto;vertical-align:top}.lp-markarea-canvas{position:absolute;left:0;top:0;width:100%;height:100%;cursor:crosshair;pointer-events:auto}.lp-markarea-hint{margin:0 0 .5rem;font-size:.75rem;color:var(--color-text-muted)}.lp-markarea-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text);margin-bottom:.35rem}.lp-markarea-suggestion{width:100%;padding:.5rem .65rem;font-size:.875rem;font-family:inherit;line-height:1.5;color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:8px;resize:vertical;margin-bottom:.75rem;box-sizing:border-box}.lp-markarea-suggestion:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #4a4dc933}.lp-markarea-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.lp-markarea-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:opacity .2s,transform .2s}.lp-markarea-btn--secondary{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border-light)}.lp-markarea-btn--secondary:hover{border-color:var(--color-primary);color:var(--color-text)}.lp-markarea-btn--primary{background:var(--gradient-primary);color:#fff;border:none}.lp-markarea-btn--primary:hover{opacity:.95;transform:translateY(-1px)}.pdf-compare-viewer{flex:1;min-height:0;overflow:visible;padding:.5rem 0}.pdf-compare-viewer--loading,.pdf-compare-viewer--error{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-muted);font-size:.9375rem}.pdf-compare-viewer--error{color:var(--color-highlight)}.pdf-compare-page{position:relative;margin-bottom:1rem;display:block}.pdf-compare-page:last-child{margin-bottom:0}.pdf-compare-page-inner{position:relative;max-width:100%;overflow:hidden}.pdf-compare-canvas{display:block;width:100%;height:auto;vertical-align:top;box-shadow:0 2px 8px #0000001a}.pdf-compare-overlay{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}.pdf-compare-overlay .pdf-compare-highlight-wrap{pointer-events:none}.pdf-compare-overlay .pdf-compare-highlight-wrap .pdf-compare-highlight-topic{pointer-events:auto}.pdf-compare-highlight-wrap{position:absolute;pointer-events:none}.pdf-compare-highlight-topic{position:absolute;left:0;top:0;width:100%;height:100%;background:#4a4dc933;border:1px solid rgba(74,77,201,.5);border-radius:3px;cursor:pointer;transition:background .2s,border-color .2s}.pdf-compare-highlight-topic:hover{background:#4a4dc959;border-color:var(--color-primary)}.pdf-compare-highlight-label{position:absolute;right:100%;top:0;margin-right:6px;font-size:.7rem;font-weight:600;color:var(--color-primary);background:#fffffffa;padding:3px 8px;border-radius:4px;border:1px solid rgba(74,77,201,.35);white-space:nowrap;box-shadow:0 1px 4px #0000001f;pointer-events:none}.pdf-compare-highlight{position:absolute;background:#dc262640;border-bottom:2px solid rgba(220,38,38,.85);pointer-events:none;border-radius:0 0 2px 2px;box-shadow:0 1px #dc262633}.content-validate-page{height:100vh;min-height:100vh;overflow:hidden;display:flex;flex-direction:column;background:var(--gradient-hero);animation:fadeIn .4s ease}.content-validate-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:.875rem 2rem 1rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.content-validate-header h1{margin:0;font-size:1.375rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.content-validate-header .header-right{display:flex;align-items:center;gap:1rem}.content-validate-header .user-pill{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem .375rem .375rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:999px;text-decoration:none;color:var(--color-text);font-size:.875rem;font-weight:600;transition:border-color .3s,box-shadow .3s,transform .2s}.content-validate-header .user-pill:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #4a4dc926;transform:translateY(-1px)}.content-validate-header .user-pill-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}.content-validate-header .user-pill:hover .user-pill-avatar{transform:scale(1.08)}.content-validate-header .user-pill-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text)}.content-validate-header .back-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.content-validate-header .back-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.content-validate-header .statistic-btn{display:inline-flex;align-items:center;gap:.4rem;padding:8px 16px;min-height:36px;background:var(--gradient-primary);color:#fff;border:none;border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s}.content-validate-header .statistic-btn:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 4px 16px #4a4dc959}.content-validate-main{flex:1;min-height:0;width:100%;padding:2rem 2rem 3rem;overflow:hidden;display:flex;flex-direction:column}.breadcrumb{flex-shrink:0;padding:1rem 1.25rem;margin-bottom:1.5rem;background:var(--gradient-card);border-radius:14px;border:1px solid var(--color-border-light);box-shadow:0 4px 16px #4a4dc90f;animation:fadeInUp .5s var(--transition-smooth) .1s both;transition:box-shadow .3s}.breadcrumb:hover{box-shadow:0 6px 20px #4a4dc91a}.content-validate-sections{flex:1;min-height:0;overflow:hidden}.breadcrumb-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 0;row-gap:.5rem}.breadcrumb-item{display:inline-flex;align-items:center;gap:.375rem}.breadcrumb-sep{color:var(--color-text-muted);font-size:.75rem;font-weight:500;-webkit-user-select:none;user-select:none;margin:0 .125rem;opacity:.8}.breadcrumb-pill{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .8rem;border-radius:8px;font-size:.8125rem;background:var(--color-bg);border:1px solid var(--color-border-light);color:var(--color-text);max-width:240px}.breadcrumb-pill-value{font-weight:600;color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breadcrumb-pill-label{color:var(--color-text-muted);font-size:.75rem;font-weight:500;flex-shrink:0;text-transform:capitalize}.breadcrumb-pill--link{background:var(--gradient-primary-soft);border-color:#4a4dc940;color:var(--color-primary);font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s,border-color .2s,transform .15s}.breadcrumb-pill--link:hover{background:#4a4dc92e;border-color:var(--color-primary);transform:translateY(-1px)}.breadcrumb-pill--current{background:linear-gradient(135deg,#4a4dc91f,#764ba214);border-color:#4a4dc966;box-shadow:0 2px 8px #4a4dc91f;border-left-width:3px;border-left-color:var(--color-primary);padding-left:calc(.8rem - 2px)}.breadcrumb-pill--current .breadcrumb-pill-value{color:var(--color-accent-purple);font-weight:700}.content-validate-sections{flex:1;min-height:0;overflow:hidden;display:grid;grid-template-columns:repeat(3,1fr);gap:0;animation:fadeInUp .5s var(--transition-smooth) .2s both}.content-validate-sections--resizable{grid-template-columns:33.33% 8px 33.34% 8px 33.33%;transition:grid-template-columns .4s cubic-bezier(.4,0,.2,1)}.cv-resizer--hidden{opacity:0;pointer-events:none;width:0!important;min-width:0!important}.cv-resizer{width:8px;min-width:8px;background:var(--color-border-light);cursor:col-resize;transition:background .2s;flex-shrink:0;position:relative;-webkit-user-select:none;user-select:none}.cv-resizer:after{content:"";position:absolute;inset:0 -4px}.cv-resizer:hover,.cv-resizer--active{background:var(--color-primary)}@media(max-width:1024px){.content-validate-sections,.content-validate-sections--resizable{grid-template-columns:1fr!important}.cv-resizer{display:none}}.cv-section{background:var(--gradient-card);border-radius:16px;border:1px solid var(--color-border-light);box-shadow:0 4px 20px #4a4dc914;overflow:hidden;transition:box-shadow .3s,transform .2s;display:flex;flex-direction:column;min-height:0;align-items:stretch}.cv-section:hover{box-shadow:0 8px 28px #4a4dc91f}.cv-section-title{margin:0;padding:1.25rem 1.5rem;font-size:1.125rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;background:var(--gradient-primary-soft);border-bottom:1px solid var(--color-border-light)}.cv-section--pdf .cv-section-title{border-left:4px solid var(--color-primary)}.cv-section--learning-plan .cv-section-title{border-left:4px solid var(--color-accent-purple)}.cv-section--visible{opacity:1;visibility:visible;transform:translate(0);transition:opacity .4s ease,transform .4s cubic-bezier(.34,1.56,.64,1)}.cv-section--hidden{opacity:0;visibility:hidden;transform:translate(20px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}.cv-section--teacher .cv-section-title{border-left:4px solid var(--color-highlight)}.feedback-toggle-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:var(--color-bg-card);border:1px solid var(--color-border-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0000000d;z-index:10}.feedback-toggle-btn:hover{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #4a4dc940;transform:translateY(-50%) scale(1.1)}.feedback-toggle-btn.active{background:var(--color-accent-purple);color:#fff;border-color:transparent}.cv-section--learning-plan .cv-section-title{display:flex;align-items:center;justify-content:space-between;position:relative;padding-right:4rem}.cv-section-body{flex:1;min-height:0;padding:1.5rem;color:var(--color-text-muted);font-size:.9375rem;line-height:1.6;overflow-y:auto;overflow-x:hidden}.cv-section-body::-webkit-scrollbar{width:6px}.cv-section-body::-webkit-scrollbar-track{background:var(--color-border-light);border-radius:3px}.cv-section-body::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:3px}.cv-section-body p{margin:0 0 .75rem}.cv-section-body p:last-child{margin-bottom:0}.cv-placeholder-hint{font-size:.875rem;color:var(--color-border)}.cv-pdf-viewer-wrap{padding:0;flex:1;min-height:0;display:flex;flex-direction:column}.cv-pdf-iframe{width:100%;flex:1;min-height:0;border:none;border-radius:0 0 16px 16px;background:var(--color-bg)}.cv-learning-plan-wrap{padding:1rem;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.cv-pdf-placeholder,.cv-learning-placeholder,.cv-teacher-placeholder{display:flex;flex-direction:column;justify-content:center;min-height:200px}.cv-label-only{font-weight:600;color:var(--color-text)}.cv-teacher-placeholder .cv-label-only{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stats-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:stats-modal-fade-in .2s ease-out}@keyframes stats-modal-fade-in{0%{opacity:0}to{opacity:1}}.stats-modal{background:var(--color-bg-card);border-radius:16px;box-shadow:0 24px 48px #0003;max-width:420px;width:100%;overflow:hidden;animation:stats-modal-scale-in .25s ease-out}@keyframes stats-modal-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.stats-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:var(--gradient-primary);color:#fff}.stats-modal-title{margin:0;font-size:1.125rem;font-weight:700;letter-spacing:-.02em}.stats-modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:background .2s}.stats-modal-close:hover{background:#ffffff59}.stats-modal-body{padding:1.25rem 1.5rem}.stats-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-bottom:1px solid var(--color-border-light);font-size:.9375rem}.stats-row:last-child{border-bottom:none}.stats-row--highlight{margin-top:.5rem;background:var(--gradient-primary-soft);border-radius:8px;padding:.75rem}.stats-label{color:var(--color-text-muted);font-weight:500}.stats-value{font-weight:700;color:var(--color-primary)}.stats-row--highlight .stats-value{color:var(--color-accent-purple)}.profile-page{min-height:100vh;background:var(--gradient-hero);animation:fadeIn .4s ease}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem 1.25rem;background:var(--gradient-header);border-bottom:1px solid var(--color-border-light);box-shadow:0 2px 12px #4a4dc90f;animation:slideInLeft .4s var(--transition-smooth) both}.profile-header h1{margin:0;font-size:1.5rem;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.header-actions{display:flex;align-items:center;gap:.75rem}.profile-header .back-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.profile-header .back-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.profile-header .logout-btn{padding:8px 16px;min-height:36px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:8px;font-family:"Poppins",inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s}.profile-header .logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #4a4dc933}.profile-main{max-width:520px;margin:0 auto;padding:3rem 2rem}.profile-card{background:var(--gradient-card);border-radius:20px;border:1px solid var(--color-border-light);padding:2.5rem;text-align:center;box-shadow:0 4px 24px #4a4dc914,0 12px 48px #0000000f;animation:scaleIn .5s var(--transition-smooth) both;transition:box-shadow .3s,transform .2s}.profile-card:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-4px)}.profile-avatar{width:88px;height:88px;margin:0 auto 1.25rem;border-radius:50%;background:var(--gradient-primary);color:#fff;font-size:1.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .15s both;box-shadow:0 8px 24px #4a4dc959;transition:transform .3s,box-shadow .3s}.profile-card:hover .profile-avatar{transform:scale(1.05);box-shadow:0 12px 32px #4a4dc966}.profile-name{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;animation:fadeInUp .5s var(--transition-smooth) .2s both}.profile-role{margin:0 0 1.75rem;font-size:.9375rem;font-weight:500;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:fadeInUp .5s var(--transition-smooth) .25s both}.profile-details{margin:0 0 1.75rem;text-align:left;padding:1.25rem 1.5rem;background:var(--gradient-primary-soft);border-radius:12px;border:1px solid rgba(74,77,201,.12);animation:fadeInUp .5s var(--transition-smooth) .3s both}.profile-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--color-border-light);gap:1rem}.profile-detail-row:last-child{border-bottom:none}.profile-detail-row dt{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.profile-detail-row dd{margin:0;font-size:.9375rem;font-weight:500;color:var(--color-text)}.profile-logout-btn{padding:12px 24px;min-height:44px;background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:10px;font-family:"Poppins",inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background .3s,color .3s,transform .2s,box-shadow .2s;animation:fadeInUp .5s var(--transition-smooth) .35s both}.profile-logout-btn:hover{background:var(--gradient-primary-soft);color:var(--color-accent-purple);transform:translateY(-2px);box-shadow:0 6px 20px #4a4dc933}#root{min-height:100vh}
