.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#6c63ff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.app-main{padding:1.5rem 1rem}}.header{background:#fff;border-bottom:1px solid #e8e8ef;position:sticky;top:0;z-index:100}.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:64px}.header-logo{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:0;font-size:1.4rem;font-weight:700;color:#1a1a2e;letter-spacing:-.02em}.logo-icon{color:#6c63ff;font-size:1.2rem}.logo-accent{color:#6c63ff}.header-nav{display:flex;gap:.25rem}.nav-link{background:none;border:none;cursor:pointer;padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#555;border-radius:8px;transition:all .2s ease}.nav-link:hover{background:#f0eeff;color:#6c63ff}.nav-link--active{background:#6c63ff;color:#fff}.nav-link--active:hover{background:#5a52e0;color:#fff}.hamburger{display:none;background:none;border:none;cursor:pointer;width:32px;height:24px;position:relative;padding:0}.hamburger span{display:block;width:100%;height:2px;background:#1a1a2e;border-radius:2px;position:absolute;left:0;transition:all .3s ease}.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:11px}.hamburger span:nth-child(3){top:22px}.hamburger.open span:nth-child(1){transform:rotate(45deg);top:11px}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg);top:11px}@media(max-width:768px){.hamburger{display:block}.header-nav{display:none;position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;padding:.5rem 1rem 1rem;border-bottom:1px solid #e8e8ef;box-shadow:0 8px 24px #00000014}.header-nav--open{display:flex}.nav-link{text-align:left;padding:.75rem 1rem;font-size:1rem}}.footer{background:#1a1a2e;color:#aaa;padding:2rem 1.5rem;margin-top:3rem}.footer-inner{max-width:1200px;margin:0 auto;text-align:center}.footer-text{font-size:.95rem;margin:0 0 .5rem;color:#ccc}.footer-logo{font-weight:700;color:#fff}.footer-sub{font-size:.8rem;margin:0;color:#777}.library-page{display:flex;flex-direction:column;gap:2rem}.library-hero{text-align:center;padding:3rem 1rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1rem;position:relative;overflow:hidden}.hero-decoration{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hero-circle{position:absolute;border-radius:50%;opacity:.08}.hero-circle--1{width:300px;height:300px;background:#6c63ff;top:-100px;right:-80px}.hero-circle--2{width:200px;height:200px;background:#e74c8b;bottom:-60px;left:-40px}.hero-circle--3{width:120px;height:120px;background:#00b894;top:20px;left:10%}.library-title{font-size:2.5rem;font-weight:800;margin:0;color:#1a1a2e;line-height:1.2;letter-spacing:-.03em;position:relative}.highlight{background:linear-gradient(135deg,#6c63ff,#e74c8b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.library-subtitle{max-width:600px;color:#666;font-size:1.1rem;line-height:1.6;margin:0;position:relative}.library-filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.filter-all{padding:.4rem 1rem;font-size:.85rem;font-weight:600;border-radius:100px;border:1.5px solid #e0e0e8;background:#fff;color:#666;cursor:pointer;transition:all .2s ease}.filter-all:hover{border-color:#6c63ff;color:#6c63ff}.filter-all--active{background:#1a1a2e;color:#fff;border-color:#1a1a2e}.library-stats{display:flex;align-items:center;gap:1rem;font-size:.85rem;color:#888}.clear-filter{background:none;border:none;color:#6c63ff;cursor:pointer;font-size:.85rem;font-weight:600;padding:0}.clear-filter:hover{text-decoration:underline}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.25rem}.library-empty{text-align:center;padding:4rem 1rem;color:#888}.empty-icon{font-size:3rem;color:#ddd;margin-bottom:1rem}.library-empty h3{margin:0 0 .5rem;color:#555}.library-empty p{margin:0}@media(max-width:768px){.library-title{font-size:1.8rem}.library-subtitle{font-size:1rem}.library-grid{grid-template-columns:1fr}.library-hero{padding:2rem .5rem 1.5rem}}.search-bar{position:relative;display:flex;align-items:center;width:100%;max-width:560px}.search-icon{position:absolute;left:1rem;font-size:1.2rem;color:#999;pointer-events:none}.search-input{width:100%;padding:.85rem 2.75rem;border:2px solid #e0e0e8;border-radius:14px;font-size:1rem;color:#1a1a2e;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;outline:none}.search-input:focus{border-color:#6c63ff;box-shadow:0 0 0 4px #6c63ff1a}.search-input::placeholder{color:#bbb}.search-clear{position:absolute;right:.75rem;background:#e8e8ef;border:none;cursor:pointer;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#666;transition:background .2s ease}.search-clear:hover{background:#d0d0da}.category-badge{display:inline-flex;align-items:center;border-radius:100px;font-weight:600;border:1.5px solid;white-space:nowrap;cursor:default;transition:all .2s ease}.category-badge--sm{padding:.25rem .75rem;font-size:.75rem}.category-badge--md{padding:.4rem 1rem;font-size:.85rem}.category-badge--clickable{cursor:pointer}.category-badge--clickable:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.prompt-card{background:#fff;border:1px solid #e8e8ef;border-radius:16px;padding:1.5rem;transition:all .25s ease;display:flex;flex-direction:column;gap:.75rem}.prompt-card:hover{border-color:#d0d0e0;box-shadow:0 4px 20px #0000000d}.prompt-card--expanded{border-color:#6c63ff40;box-shadow:0 8px 32px #6c63ff14}.prompt-card-header{display:flex;align-items:center;justify-content:space-between}.prompt-card-id{font-size:.75rem;color:#bbb;font-weight:600}.prompt-card-question{margin:0;font-size:1.05rem;font-weight:600;color:#1a1a2e;line-height:1.5}.prompt-card-body{display:none;flex-direction:column;gap:1rem}.prompt-card-body--open{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.prompt-card-prompt{background:#f7f7fb;border-radius:12px;padding:1rem 1.25rem;border-left:4px solid #6c63ff}.prompt-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6c63ff;margin-bottom:.5rem}.prompt-card-prompt p{margin:0;font-size:.92rem;line-height:1.7;color:#444}.prompt-card-meta{display:flex;justify-content:space-between;font-size:.8rem;color:#888}.copy-btn{align-self:flex-start;padding:.5rem 1rem;background:#6c63ff;color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:#5a52e0;transform:translateY(-1px)}.prompt-card-toggle{background:none;border:none;cursor:pointer;color:#6c63ff;font-size:.85rem;font-weight:600;padding:.25rem 0;align-self:flex-start;transition:color .2s ease}.prompt-card-toggle:hover{color:#5a52e0}.contribute-page{max-width:720px;margin:0 auto}.contribute-header{margin-bottom:2rem}.contribute-header h1{font-size:2rem;font-weight:800;margin:0 0 .75rem;color:#1a1a2e}.contribute-header p{color:#666;font-size:1.05rem;line-height:1.6;margin:0}.contribute-form{display:flex;flex-direction:column;gap:1.5rem;background:#fff;padding:2rem;border-radius:20px;border:1px solid #e8e8ef}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-label{font-weight:700;font-size:.95rem;color:#1a1a2e}.required{color:#e74c8b}.optional{color:#bbb;font-weight:400;font-size:.85rem}.form-hint{font-size:.82rem;color:#999;margin:0}.form-input,.form-select,.form-textarea{padding:.75rem 1rem;border:2px solid #e0e0e8;border-radius:12px;font-size:1rem;color:#1a1a2e;outline:none;transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#6c63ff;box-shadow:0 0 0 4px #6c63ff1a}.form-input--error{border-color:#e74c8b}.form-textarea{resize:vertical;min-height:120px}.form-error{font-size:.82rem;color:#e74c8b;font-weight:500}.btn{padding:.6rem 1.25rem;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease}.btn--primary{background:#6c63ff;color:#fff}.btn--primary:hover{background:#5a52e0;transform:translateY(-1px)}.btn--secondary{background:#f0eeff;color:#6c63ff}.btn--secondary:hover{background:#e0dcff}.btn--large{padding:.9rem 2rem;font-size:1.05rem;align-self:flex-start}.contribute-guidelines{margin-top:2.5rem;padding:1.5rem 2rem;background:#f7f7fb;border-radius:16px;border:1px solid #e8e8ef}.contribute-guidelines h3{margin:0 0 1rem;font-size:1.1rem;color:#1a1a2e}.contribute-guidelines ul{margin:0;padding-left:1.25rem}.contribute-guidelines li{margin-bottom:.5rem;font-size:.92rem;color:#555;line-height:1.6}.contribute-success{text-align:center;padding:4rem 2rem}.success-icon{width:80px;height:80px;background:#00b894;color:#fff;font-size:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}.contribute-success h2{margin:0 0 .5rem;color:#1a1a2e}.contribute-success p{color:#666;font-size:1.05rem;margin:0 0 2rem}.success-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.lab-page{max-width:860px;margin:0 auto}.lab-hero{text-align:center;padding:3rem 1rem 2rem;position:relative;overflow:hidden}.lab-hero-decoration{position:absolute;inset:0;pointer-events:none}.lab-shape{position:absolute}.lab-shape--triangle{width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:100px solid rgba(108,99,255,.06);top:10px;right:5%;transform:rotate(15deg)}.lab-shape--ring{width:100px;height:100px;border:12px solid rgba(231,76,139,.08);border-radius:50%;bottom:0;left:3%}.lab-shape--dot-grid{width:80px;height:80px;top:30%;left:8%;background-image:radial-gradient(circle,rgba(0,184,148,.15) 2px,transparent 2px);background-size:12px 12px}.lab-badge{display:inline-block;padding:.3rem 1rem;background:linear-gradient(135deg,#6c63ff,#e74c8b);color:#fff;border-radius:100px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;position:relative}.lab-hero h1{font-size:2.4rem;font-weight:800;margin:0 0 1rem;color:#1a1a2e;letter-spacing:-.03em;position:relative}.lab-lead{max-width:640px;margin:0 auto;color:#666;font-size:1.05rem;line-height:1.7;position:relative}.lab-section{margin-top:3rem}.lab-section h2{font-size:1.6rem;font-weight:800;margin:0 0 1rem;color:#1a1a2e;letter-spacing:-.02em}.lab-section>p{color:#555;font-size:1rem;line-height:1.7}.audience-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.audience-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border:1px solid #e8e8ef;border-radius:12px;font-size:.92rem;color:#444}.audience-icon{font-size:1.5rem}.lab-structure-intro{color:#888;font-size:.95rem;margin-bottom:1.5rem}.timeline{display:flex;flex-direction:column;gap:2rem}.timeline-day{background:#fff;border:1px solid #e8e8ef;border-radius:20px;overflow:hidden}.timeline-day-header{display:flex;align-items:center;gap:1rem;padding:1.5rem 2rem;background:linear-gradient(135deg,#fafafe,#f5f3ff);border-bottom:1px solid #e8e8ef}.day-number{width:48px;height:48px;background:linear-gradient(135deg,#6c63ff,#8b7fff);color:#fff;font-size:1.3rem;font-weight:800;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-day-header h3{margin:0;font-size:1.15rem;color:#1a1a2e}.day-sub{font-size:.82rem;color:#999}.timeline-content{padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.session{display:flex;gap:1rem}.session-time{min-width:80px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#bbb;padding-top:.15rem}.session-details{display:flex;flex-direction:column;gap:1rem;flex:1}.session-item{display:flex;gap:.75rem}.session-dot{width:10px;height:10px;border-radius:50%;margin-top:.35rem;flex-shrink:0}.session-dot--purple{background:#6c63ff}.session-dot--blue{background:#0984e3}.session-dot--pink{background:#e74c8b}.session-dot--green{background:#00b894}.session-dot--orange{background:#fdcb6e}.session-item strong{color:#1a1a2e;font-size:.95rem}.session-item p{margin:.25rem 0 0;font-size:.88rem;color:#666;line-height:1.6}.outcomes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.outcome-card{background:#fff;border:1px solid #e8e8ef;border-radius:16px;padding:1.5rem;position:relative;overflow:hidden}.outcome-bar{width:40px;height:4px;border-radius:4px;margin-bottom:1rem}.outcome-card h4{margin:0 0 .5rem;font-size:1rem;color:#1a1a2e}.outcome-card p{margin:0;font-size:.88rem;color:#666;line-height:1.6}.ethics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.ethics-card{text-align:center;padding:1.75rem 1.25rem;background:#fff;border:1px solid #e8e8ef;border-radius:16px}.ethics-icon{font-size:2rem;margin-bottom:.75rem}.ethics-card h4{margin:0 0 .5rem;color:#1a1a2e}.ethics-card p{margin:0;font-size:.88rem;color:#666;line-height:1.6}.lab-cta{text-align:center;padding:2.5rem 2rem;background:linear-gradient(135deg,#f5f3ff,#ffeef7);border-radius:20px;border:1px solid #e8e8ef}.lab-cta h3{margin:0 0 .5rem;font-size:1.3rem;color:#1a1a2e}.lab-cta p{margin:0;color:#666;font-size:.95rem}@media(max-width:768px){.lab-hero h1{font-size:1.7rem}.timeline-day-header,.timeline-content{padding:1rem 1.25rem}.session{flex-direction:column;gap:.25rem}.session-time{min-width:auto}.outcomes-grid,.ethics-grid,.audience-grid{grid-template-columns:1fr}}.tools-page{max-width:900px;margin:0 auto}.tools-hero{text-align:center;padding:2.5rem 1rem 1.5rem}.tools-hero h1{font-size:2.2rem;font-weight:800;margin:0 0 .75rem;color:#1a1a2e;letter-spacing:-.03em}.tools-hero p{max-width:600px;margin:0 auto;color:#666;font-size:1.05rem;line-height:1.6}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.25rem;margin-top:2rem}.tool-card{background:#fff;border:1px solid #e8e8ef;border-radius:20px;padding:1.75rem;display:flex;flex-direction:column;gap:1rem;transition:all .25s ease}.tool-card:hover{border-color:#d0d0e0;box-shadow:0 6px 24px #0000000d}.tool-card--featured{grid-column:1 / -1;background:linear-gradient(135deg,#fafafe,#f8f6ff);border-color:#d8d4ff}.tool-header{display:flex;align-items:center;gap:1rem}.tool-icon-wrap{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tool-icon--apertus{background:linear-gradient(135deg,#e74c8b,#ff6b9d)}.tool-icon--claude{background:linear-gradient(135deg,#6c63ff,#8b7fff)}.tool-icon--react{background:linear-gradient(135deg,#0984e3,#74b9ff)}.tool-icon--ts{background:linear-gradient(135deg,#2d79c7,#4a9eff)}.tool-icon--css{background:linear-gradient(135deg,#00b894,#55efc4)}.tool-icon--storage{background:linear-gradient(135deg,#fdcb6e,#ffeaa7)}.tool-icon-text{color:#fff;font-weight:800;font-size:1.2rem}.tool-header h3{margin:0;font-size:1.15rem;color:#1a1a2e}.tool-role{font-size:.8rem;color:#999;font-weight:500}.tool-card p{margin:0;font-size:.92rem;color:#555;line-height:1.7}.tool-specs{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid #eee}.spec{display:flex;gap:.75rem;font-size:.85rem}.spec-label{min-width:90px;color:#999;font-weight:600;text-transform:uppercase;font-size:.7rem;letter-spacing:.05em;padding-top:.1rem}.spec-value{color:#444;line-height:1.5}.architecture-section{margin-top:3rem}.architecture-section h2{font-size:1.5rem;font-weight:800;margin:0 0 1.5rem;color:#1a1a2e}.arch-diagram{display:flex;flex-direction:column;align-items:center;gap:.5rem}.arch-layer{width:100%;padding:1.25rem 1.5rem;border-radius:16px;border:1px solid #e8e8ef}.arch-layer--source{background:linear-gradient(135deg,#fff5f8,#ffeef7);border-color:#f0d0e0}.arch-layer--app{background:linear-gradient(135deg,#f5f3ff,#eee8ff);border-color:#d8d4ff}.arch-layer--data{background:linear-gradient(135deg,#e8faf5,#d1f5ec);border-color:#b0e0d0}.arch-layer--pages{background:linear-gradient(135deg,#fff8e6,#fff3cc);border-color:#f0e0a0}.arch-layer-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#999;margin-bottom:.5rem}.arch-items{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.arch-item{padding:.5rem 1rem;background:#fffc;border-radius:10px;font-size:.85rem;font-weight:600;color:#1a1a2e;border:1px solid rgba(0,0,0,.05)}.arch-item small{font-weight:400;color:#888;display:block;font-size:.75rem}.arch-arrow{color:#bbb;font-size:1.2rem}.arch-connector{color:#ccc;font-size:1rem}.open-section{margin-top:3rem}.open-card{text-align:center;padding:2.5rem 2rem;background:linear-gradient(135deg,#f5f3ff,#ffeef7,#e8faf5);border-radius:20px;border:1px solid #e8e8ef}.open-card h3{margin:0 0 .75rem;font-size:1.3rem;color:#1a1a2e}.open-card p{margin:0 auto 1.5rem;max-width:560px;color:#555;font-size:.95rem;line-height:1.7}.open-badges{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.open-badge{padding:.35rem .9rem;background:#fffc;border:1px solid #e0e0e8;border-radius:100px;font-size:.8rem;font-weight:600;color:#555}@media(max-width:768px){.tools-grid{grid-template-columns:1fr}.tools-hero h1{font-size:1.7rem}.tool-card--featured{grid-column:1}.arch-items{flex-direction:column;align-items:stretch}.arch-arrow{transform:rotate(90deg);align-self:center}}
