@charset "UTF-8";.login-page{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;display:flex;align-items:center;justify-content:center;padding:40px 20px}.login-page__bg{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.login-page__bg-circle{position:absolute;border-radius:50%;background:#e8e2d8;opacity:.5}.login-page__bg-circle--1{width:120px;height:120px;top:-30px;right:-30px;background:#e8e2d8}.login-page__bg-circle--2{width:90px;height:90px;bottom:20%;left:-30px;background:#e8e2d8}.login-page__bg-circle--3{width:60px;height:60px;bottom:10%;right:10%;background:#e8e2d8;opacity:.3}.login-page__content{width:100%;max-width:480px;position:relative;z-index:1}.login-page__logo{text-align:center;margin-bottom:32px}.login-page__logo-icon{width:64px;height:64px;margin:0 auto 12px;background:#e07a5f;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:4px 4px #4a372814}.login-page__logo-text{font-size:28px;font-weight:700;color:#4a3728;margin-bottom:6px}.login-page__logo-slogan{font-size:16px;color:#5a5a5a}.login-page__features{display:flex;justify-content:center;gap:24px;margin-bottom:40px}.login-page__feature{display:flex;flex-direction:column;align-items:center;gap:6px;color:#5a5a5a}.login-page__feature svg{color:#e07a5f}.login-page__feature span{font-size:14px}.login-page__actions{width:100%;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:32px}.login-page__input-wrap{margin-bottom:16px}.login-page__input{width:100%;height:48px;padding:0 16px;border:2px solid #4a3728;border-radius:8px;background:#fffefc;font-size:16px;color:#2c2c2c;outline:none;transition:all .2s ease}.login-page__input::placeholder{color:#9a8e80}.login-page__input:focus{border-color:#e07a5f;box-shadow:0 0 0 3px #e07a5f26}.login-page__btn{width:100%;height:48px;border-radius:8px;border:none;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s ease}.login-page__btn--primary{background:#e07a5f;color:#fff;border:1.5px solid #e07a5f}.login-page__btn--primary:hover{background:#c96a52;border-color:#c96a52}.login-page__btn--primary:active{transform:scale(.98)}.login-page__btn-icon{font-size:18px}.login-page__hint{margin-top:16px;text-align:center;font-size:14px;color:#5a5a5a}.login-page__hint-wechat{color:#e07a5f;font-weight:600}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3.2rem 1.707rem;text-align:center}.empty-state__icon{color:var(--gray-300);margin-bottom:.853rem}.empty-state__title{font-size:.853rem;font-weight:500;color:var(--gray-700);margin-bottom:.427rem}.empty-state__description{font-size:.64rem;color:var(--gray-400);margin-bottom:1.28rem;line-height:1.5}.empty-state__action{padding:.427rem 1.28rem;background:var(--gradient-primary);color:var(--white);border:none;border-radius:var(--radius-full);font-size:.64rem;font-weight:600;cursor:pointer;transition:all .2s ease}.empty-state__action:active{transform:scale(.96);opacity:.9}.pattern-list-page{min-height:100vh;background:#faf9f7;padding-bottom:60px}.pl-hero{background:linear-gradient(135deg,#fdf8f0,#f5ede0);border-bottom:1px solid #f0eeeb;padding:48px 24px 40px}.pl-hero__container{max-width:800px;margin:0 auto;text-align:center}.pl-hero__title{font-size:32px;font-weight:700;color:#2c2c2c;margin-bottom:10px;letter-spacing:.5px}.pl-hero__subtitle{font-size:16px;color:#7a7a7a;margin-bottom:28px}.pl-hero__search{max-width:560px;margin:0 auto;display:flex;align-items:center;gap:10px;padding:12px 18px;background:#fff;border-radius:14px;box-shadow:0 2px 12px #0000000f;border:1px solid #f0eeeb;color:#9e9b96;transition:all .2s}.pl-hero__search:focus-within{border-color:#c9a96e;box-shadow:0 2px 16px #c9a96e1f}.pl-hero__search input{flex:1;border:none;background:transparent;font-size:15px;color:#3d3d3d;outline:none}.pl-hero__search input::placeholder{color:#b5b2ad}.pl-hero__clear{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;background:#f0eeeb;color:#7a7a7a;border-radius:50%;font-size:11px;cursor:pointer;flex-shrink:0}.pl-hero__clear:hover{background:#e8e5e0}.pl-container{max-width:1280px;margin:0 auto;padding:28px 24px}.pl-categories{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.pl-category-chip{padding:7px 16px;border:1px solid #e8e5e0;background:#fff;border-radius:24px;font-size:13px;color:#5a5a5a;cursor:pointer;transition:all .2s;font-weight:500}.pl-category-chip.is-active{border-color:#c9a96e;background:#fdf8f0;color:#a67c3b;font-weight:600}.pl-category-chip:hover:not(.is-active){border-color:#d4cfc7;background:#faf9f7}.pl-stats{font-size:13px;color:#9e9b96;margin-bottom:20px;font-weight:500}.pl-stats__query{color:#c9a96e;font-weight:600;margin-left:4px}.pl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.pl-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 10px #0000000a;border:1px solid #f0eeeb;cursor:pointer;transition:all .25s ease;animation:fadeInUp .5s ease forwards;opacity:0}.pl-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.pl-card__image-wrapper{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:#ece8e3}.pl-card__image-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.pl-card:hover .pl-card__image-wrapper img{transform:scale(1.05)}.pl-card__overlay{position:absolute;top:12px;left:12px}.pl-card__category{padding:5px 10px;background:#ffffffeb;color:#c9a96e;font-size:11px;font-weight:600;border-radius:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pl-card__content{padding:16px}.pl-card__title{font-size:15px;font-weight:600;color:#2c2c2c;margin-bottom:8px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.pl-card__meta{display:flex;align-items:center;gap:10px}.pl-card__difficulty{padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600}.pl-card__difficulty--1{background:#10b9811a;color:#10b981}.pl-card__difficulty--2{background:#3b82f61a;color:#3b82f6}.pl-card__difficulty--3{background:#f59e0b1a;color:#f59e0b}.pl-card__difficulty--4{background:#ef44441a;color:#ef4444}.pl-card__difficulty--5{background:#8b5cf61a;color:#8b5cf6}.pl-card__time{font-size:12px;color:#9e9b96}.pl-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:#9e9b96;font-size:14px}.pl-loading__spinner{width:20px;height:20px;border:2px solid #f0eeeb;border-top-color:#c9a96e;border-radius:50%;animation:spin .8s linear infinite}.pl-no-more{text-align:center;padding:40px;color:#b5b2ad;font-size:14px}.pl-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:32px 0 16px}.pl-pagination__btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid #e8e5e0;background:#fff;color:#5a5a5a;cursor:pointer;transition:all .2s}.pl-pagination__btn:hover:not(:disabled){border-color:#c9a96e;color:#c9a96e}.pl-pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pl-pagination__info{font-size:14px;color:#7a7a7a;font-weight:500;min-width:60px;text-align:center}@media (max-width: 1024px){.pl-grid{grid-template-columns:repeat(3,1fr);gap:20px}}@media (max-width: 768px){.pl-hero{padding:32px 16px 28px}.pl-hero__title{font-size:24px}.pl-hero__subtitle{font-size:14px}.pl-container{padding:20px 16px}.pl-grid{grid-template-columns:repeat(2,1fr);gap:14px}.pl-card{border-radius:12px}.pl-card__content{padding:12px}.pl-card__title{font-size:14px}}@media (max-width: 480px){.pl-grid{grid-template-columns:1fr 1fr;gap:10px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.loading__spinner{color:var(--primary-500);animation:spin 1s linear infinite}.loading__text{margin-top:.427rem;font-size:.64rem;color:var(--gray-500)}.loading--fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.size-selector-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.size-selector-modal__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.size-selector-modal__content{position:relative;width:100%;max-width:720px;max-height:85vh;background:#fffefc;border:2px solid #4a3728;border-radius:16px;animation:fadeInScale .25s ease;display:flex;flex-direction:column;box-shadow:8px 8px #4a37281f;overflow:hidden}.size-selector-modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid #4a3728;background:#faf8f5;flex-shrink:0}.size-selector-modal__header h3{font-size:18px;font-weight:700;color:#4a3728;margin:0}.size-selector-modal__header .close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#5a5a5a;cursor:pointer;border-radius:8px;transition:all .2s ease}.size-selector-modal__header .close-btn:hover{background:#f0ebe4;color:#4a3728}.size-selector-modal__body{padding:20px;overflow-y:auto;flex:1}.size-selector-modal__hint{font-size:14px;color:#5a5a5a;margin-bottom:16px;text-align:center}.size-selector-modal__table{background:#faf8f5;border:2px solid #4a3728;border-radius:12px;overflow:hidden;margin-bottom:16px}.size-selector-modal .size-table-header{display:flex;padding:12px 10px;background:#f0ebe4;font-size:13px;font-weight:600;color:#4a3728;text-align:center;border-bottom:2px solid #4a3728}.size-selector-modal .size-table-row{display:flex;padding:14px 10px;background:none;border:none;border-bottom:1px solid #e8e2d8;width:100%;font-size:14px;color:#2c2c2c;text-align:center;cursor:pointer;transition:all .2s ease}.size-selector-modal .size-table-row:last-child{border-bottom:none}.size-selector-modal .size-table-row:hover{background:#f0ebe4}.size-selector-modal .size-table-row:active{background:#e8e2d8}.size-selector-modal .size-table-row.is-selected{background:#e07a5f;color:#fffefc;border-bottom-color:#e07a5f}.size-selector-modal .size-table-row.is-selected .size-col--highlight{color:#fffefc}.size-selector-modal .size-table-row.is-selected .fit-col,.size-selector-modal .size-table-row.is-selected .yarn-col{color:#fffefce6}.size-selector-modal .size-col{flex:0 0 12%}.size-selector-modal .size-col--highlight{font-weight:700;color:#e07a5f}.size-selector-modal .fit-col{flex:0 0 24%;font-size:13px;color:#5a5a5a}.size-selector-modal .chest-col{flex:0 0 18%}.size-selector-modal .length-col{flex:0 0 16%}.size-selector-modal .yarn-col{flex:0 0 30%;font-weight:500;color:#5a5a5a}.size-selector-modal .yarn-col .grams{margin-left:4px;font-size:12px;color:#9a8e80}.size-selector-modal__note{padding:12px;background:#faf8f5;border:2px solid #4a3728;border-radius:12px;text-align:center}.size-selector-modal__note p{font-size:13px;color:#5a5a5a;margin:0}.size-selector-modal__note p:first-child{margin-bottom:4px;font-weight:600;color:#4a3728}@keyframes fadeInScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.stitch-keyword{color:#e07a5f;font-weight:600;text-decoration:underline;text-decoration-color:#e07a5f;text-underline-offset:3px;cursor:pointer;transition:all .15s ease;border-radius:3px}.stitch-keyword:hover{background:#fff5f2;text-decoration-thickness:2px}.stitch-keyword:focus-visible{outline:2px solid #e07a5f;outline-offset:1px}.size-highlight{color:#2a9d8f;font-weight:700;background:#e8f6f4;padding:0 3px;border-radius:4px}.image-preview{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.image-preview__close{position:absolute;top:20px;right:20px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fffefc;border:2px solid #4a3728;border-radius:10px;color:#4a3728;cursor:pointer;transition:all .2s;z-index:10}.image-preview__close:hover{background:#4a3728;color:#fffefc}.image-preview__img{max-width:100%;max-height:90vh;border-radius:12px;border:2px solid #fffefc;box-shadow:0 8px 32px #0006;object-fit:contain}.stitch-detail-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.stitch-detail-modal__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#4a372873;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.stitch-detail-modal__content{position:relative;width:100%;max-width:520px;max-height:80vh;background:#fffefc;border-radius:12px;border:2px solid #4a3728;box-shadow:8px 8px #4a37281a;display:flex;flex-direction:column;overflow:hidden;animation:popIn .2s ease}.stitch-detail-modal__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid #4a3728;background:#faf8f5;flex-shrink:0}.stitch-detail-modal__title-wrap{display:flex;align-items:baseline;gap:10px}.stitch-detail-modal__title-wrap h3{font-size:18px;font-weight:700;color:#2c2c2c;margin:0}.stitch-detail-modal__abbr{font-size:13px;color:#e07a5f;font-weight:600;background:#fff5f2;padding:3px 10px;border-radius:6px;border:1.5px solid #e07a5f}.stitch-detail-modal__close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#fffefc;border:1.5px solid #4a3728;border-radius:8px;color:#4a3728;cursor:pointer;transition:all .2s}.stitch-detail-modal__close:hover{background:#4a3728;color:#fffefc}.stitch-detail-modal__body{padding:20px;overflow-y:auto}.stitch-detail-modal__gallery{margin-bottom:18px;border-radius:10px;overflow:hidden;border:2px solid #4a3728}.stitch-detail-modal__gallery img{width:100%;height:auto;display:block}.stitch-detail-modal__section{margin-bottom:18px}.stitch-detail-modal__section:last-child{margin-bottom:0}.stitch-detail-modal__section-title{font-size:13px;font-weight:700;color:#4a3728;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;padding-bottom:8px;border-bottom:1.5px solid #e8e5e0}.stitch-detail-modal__desc{font-size:15px;color:#5a5a5a;line-height:1.7;margin:0}.stitch-detail-modal__steps{display:flex;flex-direction:column;gap:12px}.stitch-detail-modal__step{display:flex;gap:12px;align-items:flex-start}.stitch-detail-modal__step-num{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:#4a3728;color:#fffefc;font-size:12px;font-weight:700;border-radius:50%;flex-shrink:0}.stitch-detail-modal__step-body{flex:1}.stitch-detail-modal__step-title{font-size:14px;font-weight:600;color:#2c2c2c;margin-bottom:4px}.stitch-detail-modal__step-content{font-size:14px;color:#5a5a5a;line-height:1.6}.stitch-detail-modal__step-images{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.stitch-detail-modal__step-img{width:120px;height:90px;object-fit:cover;border-radius:8px;border:1.5px solid #e8e5e0;cursor:pointer;transition:all .2s ease}.stitch-detail-modal__step-img:hover{border-color:#e07a5f;transform:scale(1.03)}.stitch-detail-modal__tips{margin:0;padding-left:18px;list-style:disc}.stitch-detail-modal__tips li{font-size:14px;color:#5a5a5a;line-height:1.7;margin-bottom:6px}.stitch-detail-modal__tips li:last-child{margin-bottom:0}@keyframes popIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.stitch-detail-modal{padding:0;align-items:flex-end}.stitch-detail-modal__content{max-height:85vh;border-radius:12px 12px 0 0;border-left:none;border-right:none;border-bottom:none;box-shadow:0 -4px 20px #4a37281f}}.ck-pattern-page{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;color:#3d3d3d;padding-bottom:80px}.ck-page-header{position:sticky;top:var(--nav-height, 64px);z-index:90;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid #4a3728;box-shadow:0 2px 8px #4a372814}.ck-page-header__back{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;font-size:14px;color:#4a3728;font-weight:600;transition:all .2s}.ck-page-header__back:hover{background:#4a3728;color:#fffefc}.ck-page-header__back svg{flex-shrink:0}.ck-page-header__title{font-size:18px;font-weight:700;color:#2c2c2c;margin:0;letter-spacing:.3px;flex:1;text-align:center;padding:0 20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ck-page-header__actions{display:flex;align-items:center;gap:10px}.ck-page-header__towave{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid #4a3728;background:#fffefc;color:#4a3728;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.ck-page-header__towave:hover{background:#4a3728;color:#fffefc}.ck-page-header__start{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;background:#e07a5f;color:#fff;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.ck-page-header__start:hover{background:#c96a52;transform:translateY(-1px);box-shadow:0 4px 12px #e07a5f4d}.ck-page-header__start svg{flex-shrink:0}.ck-container{max-width:960px;margin:0 auto;padding:28px 24px;display:flex;flex-direction:column;gap:20px}.ck-card{background:#fffefc;border:2px solid #4a3728;border-radius:12px;padding:24px;box-shadow:4px 4px #4a372814}.ck-card--params{border-color:#4a3728}.ck-card--collapsible{padding:0;overflow:hidden}.ck-card--collapsible .ck-card__header{cursor:pointer;padding:18px 24px;margin:0;transition:background .15s}.ck-card--collapsible .ck-card__header:hover{background:#faf8f5}.ck-card--collapsible .ck-card__body,.ck-card--collapsible .ck-materials,.ck-card--collapsible .ck-size-table{padding:0 24px 24px}.ck-card__header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.ck-card__icon{font-size:18px;line-height:1}.ck-card__title{font-size:15px;font-weight:700;color:#4a3728;letter-spacing:.5px;flex:1}.ck-card__toggle{color:#9e9b96;display:flex;align-items:center;transition:transform .2s}.ck-card__hint{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#faf8f5;border:1px dashed #d4cfc7;border-radius:8px;font-size:13px;color:#7a7a7a;margin-bottom:18px}.ck-params-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}.ck-params-col{display:flex;flex-direction:column;gap:10px}.ck-params__label{font-size:11px;color:#9e9b96;font-weight:700;text-transform:uppercase;letter-spacing:1px}.ck-params__base{font-size:12px;color:#b5b2ad}.ck-size-grid{display:flex;gap:8px;flex-wrap:wrap}.ck-size-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:2px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;color:#4a3728;transition:all .2s}.ck-size-btn:hover:not(.is-active){background:#faf8f5}.ck-size-btn.is-active{background:#4a3728;color:#fffefc;box-shadow:2px 2px #4a372833}.ck-gauge{display:flex;align-items:center;gap:10px}.ck-gauge__btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:2px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;color:#4a3728;transition:all .2s}.ck-gauge__btn:hover{background:#4a3728;color:#fffefc}.ck-gauge__value{font-size:18px;font-weight:700;color:#e07a5f;min-width:32px;text-align:center;font-variant-numeric:tabular-nums}.ck-gauge__unit{font-size:13px;color:#7a7a7a;font-weight:500}.ck-materials{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.ck-materials__col{display:flex;flex-direction:column;gap:14px}.ck-materials__subtitle{font-size:14px;font-weight:700;color:#4a3728;margin:0;padding-bottom:8px;border-bottom:1px dashed #e8e5e0}.ck-materials__group{display:flex;flex-direction:column;gap:6px}.ck-materials__group-label{font-size:11px;font-weight:700;color:#9e9b96;text-transform:uppercase;letter-spacing:.8px}.ck-materials__row{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#3d3d3d;padding:6px 0}.ck-materials__row--sub{font-size:13px;color:#7a7a7a;padding-top:0}.ck-materials__row--bullet{position:relative;padding-left:14px}.ck-materials__row--bullet:before{content:"•";position:absolute;left:0;color:#c9a96e;font-weight:700}.ck-materials__gram{font-size:13px;font-weight:600;color:#e07a5f;background:#fff5f2;padding:2px 8px;border-radius:5px}.ck-materials__empty{font-size:14px;color:#b5b2ad;font-style:italic}.ck-size-table{display:flex;flex-direction:column;gap:0}.ck-size-table__header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding:10px 0;font-size:11px;font-weight:700;color:#9e9b96;text-transform:uppercase;letter-spacing:.8px;border-bottom:2px solid #4a3728}.ck-size-table__row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding:12px 0;font-size:14px;color:#5a5a5a;border-bottom:1px dashed #e8e5e0}.ck-size-table__row:last-child{border-bottom:none}.ck-size-table__row span:first-child{font-weight:600;color:#3d3d3d}.ck-size-table__result{color:#e07a5f;font-weight:700}.ck-core-data{background:#fffefc;border:2px solid #4a3728;border-radius:12px;padding:24px;box-shadow:4px 4px #4a372814}.ck-core-data__header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.ck-core-data__icon{font-size:18px;line-height:1}.ck-core-data__title{font-size:15px;font-weight:700;color:#4a3728;letter-spacing:.5px}.ck-core-data__hint{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#faf8f5;border:1px dashed #d4cfc7;border-radius:8px;font-size:13px;color:#7a7a7a;margin-bottom:20px}.ck-core-data__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.ck-core-card{background:#fffefc;border:1.5px solid #e8e5e0;border-radius:10px;padding:18px;border-left-width:5px;transition:transform .2s,box-shadow .2s}.ck-core-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000000f}.ck-core-card--c0{border-left-color:#2d8a5e}.ck-core-card--c1{border-left-color:#d4a017}.ck-core-card--c2{border-left-color:#4a7fc1}.ck-core-card--c3{border-left-color:#7c5cc7}.ck-core-card__header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.ck-core-card__bullet{font-size:12px;color:#9e9b96}.ck-core-card__section{font-size:13px;font-weight:700;color:#4a3728}.ck-core-card__row{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:8px 0;border-bottom:1px dashed #f0eeeb}.ck-core-card__row:last-child{border-bottom:none}.ck-core-card__label{font-size:13px;color:#5a5a5a;word-break:break-word}.ck-core-card__value{font-size:15px;font-weight:700;color:#2c2c2c;font-variant-numeric:tabular-nums;text-align:right;word-break:break-word;flex-shrink:0}.ck-core-card__value small{font-size:12px;font-weight:500;color:#9e9b96;margin-left:3px}.ck-construction-notes{display:flex;flex-direction:column;gap:8px}.ck-construction-notes__item{font-size:14px;color:#5a5a5a;line-height:1.7;margin:0;padding-left:16px;position:relative;white-space:pre-wrap}.ck-construction-notes__item:before{content:"•";position:absolute;left:0;color:#e07a5f;font-weight:700}.ck-instructions__title{font-size:18px;font-weight:700;color:#4a3728;margin-bottom:16px;letter-spacing:.5px}.ck-instructions__body{display:flex;gap:20px;align-items:flex-start}.ck-instruction-nav{position:sticky;top:88px;z-index:85;width:180px;flex-shrink:0;align-self:flex-start;background:#fffefc;border:1.5px solid #e8e5e0;border-radius:10px;padding:12px 16px;box-shadow:0 2px 8px #4a37280f;max-height:calc(100vh - 120px);overflow-y:auto}.ck-instruction-nav__scroll{display:flex;flex-direction:column;gap:2px}.ck-instruction-nav__item{display:flex;align-items:flex-start;gap:8px;padding:7px 10px;border:none;background:transparent;border-radius:6px;font-size:13px;color:#7a7a7a;font-weight:500;cursor:pointer;text-align:left;line-height:1.4;transition:all .15s;word-break:break-word}.ck-instruction-nav__item:before{content:"";display:block;width:6px;height:6px;border-radius:50%;background:#d4cfc7;flex-shrink:0}.ck-instruction-nav__item.is-section{color:#4a3728;font-weight:700;font-size:14px;margin-top:4px}.ck-instruction-nav__item.is-section:before{width:8px;height:8px;background:#c9a96e;border-radius:2px}.ck-instruction-nav__item.is-active{background:#fdf8f0;color:#4a3728;font-weight:600}.ck-instruction-nav__item.is-active:before{background:#4a3728}.ck-instruction-nav__item:hover{background:#faf8f5;color:#4a3728}.ck-steps{flex:1;min-width:0;display:flex;flex-direction:column;gap:12px}.ck-step-section{padding:24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;text-align:center;box-shadow:4px 4px #4a372814;margin-bottom:4px}.ck-step-section__title{font-size:18px;font-weight:700;color:#4a3728;margin-bottom:6px}.ck-step-section__desc{font-size:14px;color:#7a7a7a;line-height:1.5;margin:0;white-space:pre-wrap}.ck-step{padding:20px 24px;background:#fffefc;border:1.5px solid #e8e5e0;border-radius:10px;transition:border-color .2s}.ck-step:hover{border-color:#c9a96e}.ck-step__number{font-size:12px;color:#c9a96e;font-weight:600;margin-bottom:8px;letter-spacing:.5px}.ck-step__title{font-size:16px;font-weight:700;color:#2c2c2c;margin-bottom:10px}.ck-step__content{font-size:15px;color:#4a4a4a;line-height:1.75;margin:0;white-space:pre-wrap}.ck-step__note{display:flex;align-items:flex-start;gap:8px;margin-top:12px;padding:12px 14px;background:#fff8e6;border:1px dashed #f5e0a3;border-radius:8px;font-size:13px;color:#a67c00;font-weight:500}.empty-hint{display:flex;align-items:center;justify-content:center;min-height:60vh;font-size:16px;color:#9e9b96}@media (max-width: 768px){.ck-page-header{padding:10px 16px;flex-wrap:wrap;gap:8px}.ck-page-header__title{font-size:15px;order:3;flex-basis:100%;text-align:left;padding:0}.ck-page-header__actions{margin-left:auto}.ck-page-header__towave{padding:6px 12px;font-size:13px}.ck-page-header__start{padding:8px 14px;font-size:13px}.ck-container{padding:16px}.ck-materials,.ck-core-data__grid{grid-template-columns:1fr}.ck-size-table__header,.ck-size-table__row{grid-template-columns:1.2fr 1fr 1fr;font-size:13px}.ck-params-grid{grid-template-columns:1fr}.ck-step__content{word-break:break-word;overflow-wrap:break-word}.ck-instructions__body{flex-direction:column}.ck-instruction-nav{position:relative;top:auto;width:100%;max-height:none}.ck-size-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.ck-size-table__header,.ck-size-table__row{min-width:320px;grid-template-columns:1.2fr 1fr 1fr;font-size:13px}.ck-core-card__value{max-width:50%}}.stitch-list-page{min-height:100%;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding-bottom:48px}.stitch-list-page__search{position:sticky;top:0;z-index:10;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.stitch-list-page__categories{position:sticky;top:64px;z-index:10;background:#fffefc;padding:12px 28px;border-bottom:2px solid #4a3728}.stitch-list-page__content{max-width:960px;margin:0 auto;padding:24px 28px}.stitch-list-page__loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px;color:#5a5a5a;font-size:14px}.stitch-list-page__no-more{text-align:center;padding:24px;color:#5a5a5a;font-size:14px}.stitch-list-page__upload{position:fixed;right:24px;bottom:56px;width:48px;height:48px;border-radius:12px;border:2px solid #4a3728;background:#e07a5f;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:4px 4px #4a37281f;cursor:pointer;z-index:100;transition:all .2s ease}.stitch-list-page__upload:hover{background:#c96a52}.search-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.search-bar__icon{color:#5a5a5a;flex-shrink:0}.search-bar__input{flex:1;border:none;background:transparent;font-size:16px;color:#2c2c2c;outline:none}.search-bar__input::placeholder{color:#9a8e80}.search-bar__clear{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:none;background:#4a3728;color:#fffefc;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease}.search-bar__clear:hover{background:#2c1e12}.category-tabs{display:flex;gap:10px;overflow-x:auto;padding-bottom:2px}.category-tabs::-webkit-scrollbar{display:none}.category-tab{flex-shrink:0;padding:8px 18px;border-radius:8px;border:1.5px solid #4a3728;background:#fffefc;color:#4a3728;font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.category-tab.is-active,.category-tab:hover{background:#4a3728;color:#fffefc}.stitch-list{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.stitch-card{display:flex;flex-direction:column;background:#fffefc;border:2px solid #4a3728;border-radius:12px;overflow:hidden;box-shadow:4px 4px #4a372814;cursor:pointer;animation:fadeInUp .4s ease forwards;opacity:0}.stitch-card__image-wrapper{position:relative;width:100%;aspect-ratio:4/5;flex-shrink:0;overflow:hidden}.stitch-card__image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.stitch-card:hover .stitch-card__image{transform:scale(1.05)}.stitch-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0ebe4;color:#9a8e80;font-size:48px;font-weight:700;-webkit-user-select:none;user-select:none}.stitch-card__category{position:absolute;top:8px;left:8px;padding:4px 10px;background:#4a3728d9;color:#fffefc;font-size:12px;border-radius:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.stitch-card__content{flex:1;padding:14px;display:flex;flex-direction:column;min-width:0}.stitch-card__title{font-size:16px;font-weight:600;color:#4a3728;margin-bottom:6px}.stitch-card__desc{font-size:13px;color:#5a5a5a;line-height:1.5;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1}.stitch-card__footer{display:flex;align-items:center;justify-content:flex-end;margin-top:10px}.stitch-card__arrow{color:#9a8e80}.loading-spinner{width:20px;height:20px;border:2px solid #e8e2d8;border-top-color:#e07a5f;border-radius:50%;animation:spin .8s linear infinite}.stitch-list-page__pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:32px 0 16px}.stitch-list-page__page-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid #e8e2d8;background:#fffefc;color:#4a3728;cursor:pointer;transition:all .2s}.stitch-list-page__page-btn:hover:not(:disabled){border-color:#e07a5f;color:#e07a5f}.stitch-list-page__page-btn:disabled{opacity:.4;cursor:not-allowed}.stitch-list-page__page-info{font-size:14px;color:#7a7a7a;font-weight:500;min-width:60px;text-align:center}@media (max-width: 1024px){.stitch-list{grid-template-columns:repeat(3,1fr);gap:20px}}@media (max-width: 768px){.stitch-list{grid-template-columns:repeat(2,1fr);gap:14px}}@media (max-width: 480px){.stitch-list{grid-template-columns:1fr;gap:10px}}.stitch-detail-page{min-height:100%;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding-bottom:56px}.stitch-detail-page__header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.stitch-detail-page__header .back-btn,.stitch-detail-page__header .action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:2px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#4a3728}.stitch-detail-page__header .back-btn:hover,.stitch-detail-page__header .action-btn:hover{background:#4a3728;color:#fffefc}.stitch-detail-page__header .header-actions{display:flex;gap:8px}.stitch-detail-page__gallery{position:relative;width:100%;max-width:560px;margin:64px auto 0;aspect-ratio:1/1;background:#e8e2d8;border:2px solid #4a3728;border-radius:12px;overflow:hidden;box-shadow:4px 4px #4a372814}.stitch-detail-page__gallery .image-swiper{width:100%;height:100%;position:relative;overflow:hidden}.stitch-detail-page__gallery .image-swiper__slide{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease}.stitch-detail-page__gallery .image-swiper__slide.is-active{opacity:1}.stitch-detail-page__gallery .image-swiper__indicators{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px}.stitch-detail-page__gallery .image-swiper__indicators .indicator{width:10px;height:10px;border-radius:50%;border:none;background:#fffefc80;cursor:pointer;transition:all .2s ease}.stitch-detail-page__gallery .image-swiper__indicators .indicator.is-active{width:28px;border-radius:6px;background:#fffefc}.stitch-detail-page__gallery .image-nav{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:2px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;transition:all .2s ease;color:#4a3728}.stitch-detail-page__gallery .image-nav--prev{left:12px}.stitch-detail-page__gallery .image-nav--next{right:12px}.stitch-detail-page__gallery .image-nav:hover{background:#4a3728;color:#fffefc}.stitch-detail-page__gallery .like-float-btn{position:absolute;right:16px;bottom:48px;width:40px;height:40px;border-radius:8px;border:2px solid #4a3728;background:#fffefc;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#e07a5f;box-shadow:4px 4px #4a372814}.stitch-detail-page__gallery .like-float-btn:hover{background:#e07a5f;color:#fffefc}.stitch-detail-page__info{max-width:960px;margin:20px auto;padding:20px 24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.stitch-detail-page__info .stitch-header{margin-bottom:12px}.stitch-detail-page__info .stitch-header .stitch-category{display:inline-block;padding:4px 12px;background:#faf8f5;color:#4a3728;font-size:13px;border-radius:8px;margin-bottom:8px;border:1.5px solid #4a3728}.stitch-detail-page__info .stitch-header .stitch-name{font-size:24px;font-weight:700;color:#2c2c2c}.stitch-detail-page__info .stitch-desc{font-size:15px;color:#5a5a5a;line-height:1.7;margin-bottom:12px}.stitch-detail-page__info .stitch-stats{display:flex;gap:20px;padding-top:12px;border-top:1.5px solid #e8e2d8}.stitch-detail-page__info .stitch-stats .stat-item{display:flex;align-items:center;gap:6px;font-size:14px;color:#5a5a5a}.stitch-detail-page__tutorial{max-width:960px;margin:20px auto;padding:20px 24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.stitch-detail-page__tutorial .section-title{font-size:20px;font-weight:600;color:#2c2c2c;margin-bottom:16px}.stitch-detail-page__tutorial .tutorial-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.stitch-detail-page__tutorial .tutorial-step{display:flex;align-items:flex-start;gap:14px;padding:14px;background:#faf8f5;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease}.stitch-detail-page__tutorial .tutorial-step.is-active{background:#fffefc;border-color:#e07a5f;box-shadow:4px 4px #e07a5f1f}.stitch-detail-page__tutorial .tutorial-step__number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#e07a5f;color:#fffefc;font-size:14px;font-weight:600;border-radius:8px;flex-shrink:0}.stitch-detail-page__tutorial .tutorial-step__content{flex:1;min-width:0}.stitch-detail-page__tutorial .tutorial-step__title{font-size:16px;font-weight:600;color:#2c2c2c;margin-bottom:4px}.stitch-detail-page__tutorial .tutorial-step__desc{font-size:14px;color:#5a5a5a;line-height:1.5}.stitch-detail-page__tutorial .tutorial-step__images{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.stitch-detail-page__tutorial .tutorial-step__img{width:120px;height:90px;object-fit:cover;border-radius:8px;border:1.5px solid #e8e2d8;transition:all .2s ease}.stitch-detail-page__tutorial .tutorial-step__img:hover{border-color:#e07a5f;transform:scale(1.03)}.stitch-detail-page__tutorial .tutorial-step:hover{background:#f5efe8}.stitch-detail-page__tutorial .step-navigator{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#faf8f5;border:2px solid #4a3728;border-radius:12px;flex-wrap:nowrap}.stitch-detail-page__tutorial .step-navigator .step-nav-btn{display:flex;align-items:center;gap:4px;padding:8px 16px;border:1.5px solid #4a3728;background:#fffefc;font-size:14px;color:#4a3728;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.stitch-detail-page__tutorial .step-navigator .step-nav-btn:disabled{opacity:.5;cursor:not-allowed}.stitch-detail-page__tutorial .step-navigator .step-nav-btn:hover:not(:disabled){background:#4a3728;color:#fffefc}.stitch-detail-page__tutorial .step-navigator .step-counter{flex:1;text-align:center;font-size:14px;color:#5a5a5a;font-weight:500;min-width:0}.stitch-detail-page__tips{max-width:960px;margin:20px auto;padding:20px 24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.stitch-detail-page__tips .section-title{font-size:20px;font-weight:600;color:#2c2c2c;margin-bottom:16px}.stitch-detail-page__tips .tips-list{display:flex;flex-direction:column;gap:10px}.stitch-detail-page__tips .tip-item{display:flex;align-items:flex-start;gap:10px;padding:12px;background:#faf8f5;border:1.5px solid #e8e2d8;border-radius:12px}.stitch-detail-page__tips .tip-item__dot{width:8px;height:8px;background:#e07a5f;border-radius:50%;margin-top:7px;flex-shrink:0}.stitch-detail-page__tips .tip-item__text{font-size:14px;color:#3d3d3d;line-height:1.6}.stitch-detail-page__footer{position:fixed;bottom:40px;left:0;right:0;padding:14px 28px;background:#fffefc;border-top:2px solid #4a3728;display:flex;gap:12px;max-width:960px;margin:0 auto}.stitch-detail-page__footer .action-btn-primary,.stitch-detail-page__footer .action-btn-secondary{flex:1;height:44px;border-radius:8px;border:1.5px solid #4a3728;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.stitch-detail-page__footer .action-btn-primary:hover,.stitch-detail-page__footer .action-btn-secondary:hover{transform:translateY(-1px)}.stitch-detail-page__footer .action-btn-primary{background:#e07a5f;border-color:#e07a5f;color:#fff}.stitch-detail-page__footer .action-btn-primary:hover{background:#c96a52;border-color:#c96a52}.stitch-detail-page__footer .action-btn-secondary{background:#fffefc;color:#4a3728}.stitch-detail-page__footer .action-btn-secondary:hover{background:#4a3728;color:#fffefc}@media (max-width: 768px){.stitch-detail-page__tutorial .step-navigator{padding:8px;gap:6px}.stitch-detail-page__tutorial .step-navigator .step-nav-btn{padding:5px 10px;font-size:12px}.stitch-detail-page__tutorial .step-navigator .step-counter{font-size:11px}}@media (max-width: 480px){.stitch-detail-page__tutorial .step-navigator{padding:6px;gap:4px}.stitch-detail-page__tutorial .step-navigator .step-nav-btn{padding:4px 8px;font-size:11px}.stitch-detail-page__tutorial .step-navigator .step-counter{font-size:10px}}.project-list-page{background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding-bottom:48px}.project-list-page__header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.project-list-page__header h1{font-size:20px;font-weight:700;color:#4a3728}.project-list-page__header .add-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1.5px solid #4a3728;background:#fffefc;color:#4a3728;border-radius:8px;cursor:pointer;transition:all .2s ease}.project-list-page__header .add-btn:hover{background:#4a3728;color:#fffefc}.project-list-page__content{max-width:960px;margin:0 auto;padding:24px}.project-list{display:flex;flex-direction:column;gap:16px}.project-card{display:flex;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;overflow:hidden;cursor:pointer;animation:fadeInUp .4s ease forwards;opacity:0}.project-card__image-wrapper{position:relative;width:120px;height:120px;flex-shrink:0;overflow:hidden}.project-card__image-wrapper img{width:100%;height:100%;object-fit:cover}.project-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0ebe4;color:#9a8e80;font-size:32px;font-weight:700;-webkit-user-select:none;user-select:none}.project-card__status{position:absolute;top:8px;left:8px;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:500;display:flex;align-items:center;gap:4px}.project-card__status--ongoing{background:#fef3c7;color:#b45309}.project-card__status--completed{background:#d1fae5;color:#047857}.project-card__status--paused{background:#f3f4f6;color:#4b5563}.project-card__content{flex:1;padding:16px;display:flex;flex-direction:column;min-width:0}.project-card__title{font-size:18px;font-weight:600;color:#2c2c2c;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card__meta{display:flex;gap:12px;margin-bottom:8px}.project-card__meta span{font-size:14px;color:#5a5a5a}.project-card__progress{display:flex;align-items:center;gap:8px;margin-bottom:8px}.project-card__progress .progress-bar{flex:1;height:8px;background:#f0ebe4;border-radius:8px;overflow:hidden}.project-card__progress .progress-bar__fill{height:100%;background:linear-gradient(90deg,#e07a5f,#f0947a);border-radius:8px;transition:width .3s ease}.project-card__progress .progress-text{font-size:14px;color:#e07a5f;font-weight:600}.project-card__steps{display:flex;align-items:center;justify-content:space-between}.project-card__steps span{font-size:14px;color:#5a5a5a}.project-card__steps .continue-text{color:#e07a5f;font-weight:500}.project-card:active{opacity:.8}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.project-detail-page{background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding-bottom:0}.project-detail-page__header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.project-detail-page__header h1{font-size:18px;font-weight:600;color:#4a3728}.project-detail-page__header .back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#4a3728;cursor:pointer;border-radius:8px;transition:background .2s ease}.project-detail-page__header .back-btn:hover{background:#f0ebe4}.project-detail-page__header .placeholder{width:36px}.project-detail-page__overview{max-width:960px;margin:0 auto;padding:24px}.project-detail-page__overview .overview-card{display:flex;gap:16px;padding:16px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.project-detail-page__overview .overview-card__image{width:120px;height:120px;border-radius:8px;object-fit:cover}.project-detail-page__overview .overview-card__info{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px}.project-detail-page__overview .overview-card__meta{display:flex;align-items:center;gap:8px}.project-detail-page__overview .overview-card .status-badge{display:inline-flex;align-self:flex-start;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:500;background:#fef3c7;color:#b45309}.project-detail-page__overview .overview-card .size-tag{display:inline-flex;padding:4px 10px;border-radius:8px;font-size:12px;font-weight:500;background:#f0ebe4;color:#4a3728}.project-detail-page__overview .overview-card__progress .progress-bar{width:100%;height:8px;background:#f0ebe4;border-radius:8px;margin-top:4px;overflow:hidden}.project-detail-page__overview .overview-card__progress .progress-bar__fill{height:100%;background:linear-gradient(90deg,#e07a5f,#f0947a);border-radius:8px;transition:width .3s ease}.project-detail-page__overview .overview-card__progress .progress-label{display:block;font-size:14px;color:#5a5a5a;margin-top:4px}.project-detail-page__overview .overview-card__stats{display:flex;gap:24px;margin-top:4px}.project-detail-page__overview .overview-card__stats .stat{display:flex;align-items:center;gap:4px;color:#5a5a5a}.project-detail-page__overview .overview-card__stats .stat__value{font-size:16px;font-weight:700;color:#2c2c2c}.project-detail-page__overview .overview-card__stats .stat__label{font-size:12px;color:#5a5a5a}.project-detail-page__overview .overview-card__continue{align-self:flex-start;margin-top:4px;padding:8px 18px;border-radius:8px;border:2px solid #4a3728;background:#e07a5f;color:#fffefc;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.project-detail-page__overview .overview-card__continue:hover{background:#c96a52}.project-detail-page__current-step{max-width:960px;margin:0 auto;padding:0 24px 16px}.project-detail-page__current-step .current-step-hero{background:#fffefc;border:2px solid #4a3728;border-radius:12px;padding:24px;box-shadow:4px 4px #4a372814}.project-detail-page__current-step .current-step-hero__header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.project-detail-page__current-step .current-step-hero__badge{display:inline-flex;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;background:#e07a5f;color:#fff}.project-detail-page__current-step .current-step-hero__number{font-size:14px;color:#5a5a5a;font-weight:500}.project-detail-page__current-step .current-step-hero__title{font-size:20px;font-weight:700;color:#2c2c2c;margin-bottom:12px;line-height:1.4}.project-detail-page__current-step .current-step-hero__content{font-size:16px;color:#3d3d3d;line-height:1.7;margin-bottom:16px}.project-detail-page__current-step .current-step-hero__tip{display:flex;align-items:flex-start;gap:8px;padding:12px;background:#fef3c7;border-radius:8px;font-size:14px;color:#5a5a5a;margin-bottom:16px}.project-detail-page__current-step .current-step-hero__tip .tip-icon{flex-shrink:0;width:18px;height:18px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23b45309' stroke-width='2'%3E%3Cpath d='M9.663 17h4.673M12 3v1m6.364 1.636l-.707.707M21 12h-1M4 12H3m3.343-5.657l-.707-.707m2.828 9.9a5 5 0 117.072 0l-.548.547A3.374 3.374 0 0014 18.469V19a2 2 0 11-4 0v-.531c0-.895-.356-1.754-.988-2.386l-.548-.547z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center}.project-detail-page__current-step .current-step-hero__nav{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding-top:16px;border-top:2px solid #f0ebe4;flex-wrap:nowrap}.project-detail-page__current-step .step-nav-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:10px 18px;border:1.5px solid #4a3728;background:#fffefc;color:#4a3728;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;min-height:40px;min-width:80px;white-space:nowrap;flex-shrink:0}.project-detail-page__current-step .step-nav-btn:hover:not(:disabled){background:#4a3728;color:#fffefc}.project-detail-page__current-step .step-nav-btn:disabled{opacity:.4;cursor:not-allowed}.project-detail-page__current-step .step-nav-btn--primary{background:#e07a5f;border-color:#e07a5f;color:#fff}.project-detail-page__current-step .step-nav-btn--primary:hover:not(:disabled){background:#c96a52;border-color:#c96a52;color:#fff}.project-detail-page__current-step .step-dots{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;min-width:0;overflow-x:auto}.project-detail-page__current-step .step-dot{width:10px;height:10px;border-radius:50%;background:#f0ebe4;cursor:pointer;transition:all .2s ease}.project-detail-page__current-step .step-dot.is-active{background:#e07a5f;transform:scale(1.2)}.project-detail-page__current-step .step-dots-more{font-size:12px;color:#5a5a5a;margin-left:2px}.project-detail-page__quick-log{max-width:960px;margin:0 auto;padding:0 24px 24px}.project-detail-page__quick-log .quick-log-card{background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;overflow:hidden}.project-detail-page__quick-log .quick-log-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;-webkit-user-select:none;user-select:none}.project-detail-page__quick-log .quick-log-header__left{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#2c2c2c}.project-detail-page__quick-log .quick-log-header__arrow{color:#5a5a5a;transition:transform .2s ease}.project-detail-page__quick-log .quick-log-header__arrow.is-expanded{transform:rotate(180deg)}.project-detail-page__quick-log .quick-log-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#e07a5f;color:#fff;border-radius:8px;font-size:12px;font-weight:700}.project-detail-page__quick-log .quick-log-body{padding:0 18px 18px}.project-detail-page__quick-log .quick-log-body textarea{width:100%;padding:12px;border:1.5px solid #f0ebe4;border-radius:8px;font-size:14px;color:#3d3d3d;resize:none;outline:none;margin-bottom:12px;background:#fffefc}.project-detail-page__quick-log .quick-log-body textarea:focus{border-color:#e07a5f}.project-detail-page__quick-log .quick-log-body textarea::placeholder{color:#a8a29e}.project-detail-page__quick-log .quick-log-submit{width:100%;padding:12px;border:none;border-radius:8px;background:#e07a5f;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s ease}.project-detail-page__quick-log .quick-log-submit:hover{background:#c96a52}.project-detail-page__quick-log .quick-log-preview{padding:0 18px 18px;display:flex;flex-direction:column;gap:8px}.project-detail-page__quick-log .quick-log-preview__item{display:flex;align-items:center;gap:8px}.project-detail-page__quick-log .quick-log-preview__thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1.5px solid #f0ebe4}.project-detail-page__quick-log .quick-log-preview__text{font-size:14px;color:#5a5a5a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-detail-page__quick-log .quick-log-preview__more{font-size:12px;color:#5a5a5a}.project-detail-page__collapsible{max-width:960px;margin:0 auto;padding:0 24px 24px}.project-detail-page__collapsible .collapsible-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:12px}.project-detail-page__collapsible .collapsible-header .section-title{margin-bottom:0}.project-detail-page__collapsible .collapsible-arrow{color:#5a5a5a;transition:transform .2s ease;display:flex;align-items:center}.project-detail-page__collapsible .collapsible-arrow.is-expanded{transform:rotate(180deg)}.project-detail-page__materials .materials-card{background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:16px;display:flex;flex-direction:column;gap:8px}.project-detail-page__materials .material-item{display:flex;gap:8px}.project-detail-page__materials .material-item__label{font-size:14px;color:#5a5a5a;white-space:nowrap;flex-shrink:0}.project-detail-page__materials .material-item__value{font-size:14px;color:#3d3d3d;line-height:1.4}.project-detail-page__instructions{max-width:960px;margin:0 auto;padding:0 24px 24px}.project-detail-page__instructions .section-title{font-size:20px;font-weight:600;color:#2c2c2c;margin-bottom:0}.project-detail-page__instructions .instruction-mode-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.project-detail-page__instructions .instruction-mode-tabs{display:flex;align-items:center;gap:4px;background:#f0ebe4;padding:4px;border-radius:8px}.project-detail-page__instructions .instruction-mode-tab{padding:6px 14px;border:none;border-radius:6px;font-size:14px;font-weight:500;color:#5a5a5a;background:transparent;cursor:pointer;transition:all .2s ease}.project-detail-page__instructions .instruction-mode-tab.is-active{background:#fffefc;color:#4a3728;font-weight:600;box-shadow:0 1px 3px #4a372814}.project-detail-page__instructions .instruction-mode-tab:hover:not(.is-active){color:#4a3728}.project-detail-page__instructions .instruction-merged .current-step-hero{background:transparent;border:none;box-shadow:none;padding:8px;margin:-8px}.project-detail-page__instructions .instruction-merged .current-step-hero__nav{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:24px;padding-top:16px;border-top:2px solid #f0ebe4;flex-wrap:nowrap}.project-detail-page__instructions .instruction-merged .step-nav-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:10px 18px;border:1.5px solid #4a3728;background:#fffefc;color:#4a3728;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;min-height:40px;min-width:80px;white-space:nowrap;flex-shrink:0}.project-detail-page__instructions .instruction-merged .step-nav-btn:hover:not(:disabled){background:#4a3728;color:#fffefc}.project-detail-page__instructions .instruction-merged .step-nav-btn:disabled{opacity:.4;cursor:not-allowed}.project-detail-page__instructions .instruction-merged .step-nav-btn--primary{background:#e07a5f;border-color:#e07a5f;color:#fff}.project-detail-page__instructions .instruction-merged .step-nav-btn--primary:hover:not(:disabled){background:#c96a52;border-color:#c96a52;color:#fff}.project-detail-page__instructions .instruction-merged .step-dots{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;min-width:0;overflow-x:auto}.project-detail-page__instructions .instruction-merged .step-dot{width:10px;height:10px;border-radius:50%;background:#f0ebe4;cursor:pointer;transition:all .2s ease}.project-detail-page__instructions .instruction-merged .step-dot.is-active{background:#e07a5f;transform:scale(1.2)}.project-detail-page__instructions .instruction-merged .step-dots-more{font-size:12px;color:#5a5a5a;margin-left:2px}.project-detail-page__instructions .instruction-step-rows{margin-top:16px;padding-top:16px;border-top:2px solid #f0ebe4}.project-detail-page__instructions .instruction-step-rows__title{font-size:14px;font-weight:600;color:#4a3728;margin-bottom:10px}.project-detail-page__instructions .instruction-step-rows__item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid #f0ebe4}.project-detail-page__instructions .instruction-step-rows__item:last-child{border-bottom:none}.project-detail-page__instructions .instruction-step-rows__badge{flex-shrink:0;min-width:40px;padding:3px 8px;background:#f0ebe4;color:#4a3728;font-size:12px;font-weight:600;border-radius:6px;text-align:center}.project-detail-page__instructions .instruction-step-rows__text{font-size:15px;color:#3d3d3d;line-height:1.6;flex:1}.project-detail-page__instructions .instruction-step-rows__item.is-keypoint{background:#e07a5f14;border-radius:8px;margin:0 -4px;padding:8px 4px}.project-detail-page__instructions .instruction-step-rows__item.is-keypoint .instruction-step-rows__badge{background:#e07a5f;color:#fff}.project-detail-page__instructions .instruction-auto-rows{display:flex;flex-direction:column;gap:6px}.project-detail-page__instructions .instruction-auto-rows__item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:#faf8f5;border-radius:10px;border:1.5px solid transparent;transition:all .2s ease}.project-detail-page__instructions .instruction-auto-rows__item:hover{border-color:#e8e2d8}.project-detail-page__instructions .instruction-auto-rows__badge{flex-shrink:0;min-width:44px;padding:4px 10px;background:#f0ebe4;color:#4a3728;font-size:12px;font-weight:600;border-radius:6px;text-align:center;margin-top:2px}.project-detail-page__instructions .instruction-auto-rows__text{font-size:15px;color:#3d3d3d;line-height:1.6;flex:1}.project-detail-page__instructions .instruction-merged{background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:16px}.project-detail-page__instructions .instruction-merged__divider{height:1px;background:#f0ebe4;margin:16px 0}.project-detail-page__instructions .instruction-merged__section{font-size:18px;font-weight:700;color:#2c2c2c;margin:12px 0 8px}.project-detail-page__instructions .instruction-merged__desc{font-size:14px;color:#5a5a5a;margin-bottom:8px}.project-detail-page__instructions .instruction-merged__item{padding:12px 0;border-bottom:1px solid #f0ebe4}.project-detail-page__instructions .instruction-merged__item:last-child{border-bottom:none}.project-detail-page__instructions .instruction-merged__item.is-current{background:#e07a5f0f;border-radius:8px;padding:12px;margin:0 -4px}.project-detail-page__instructions .instruction-merged__text{font-size:15px;color:#3d3d3d;line-height:1.7;margin:0}.project-detail-page__instructions .instruction-merged__rich-text{background:#fffefc;border:1.5px solid #f0ebe4;border-radius:8px;padding:12px;font-size:15px;color:#3d3d3d;line-height:1.7;overflow-wrap:break-word;word-break:break-word}.project-detail-page__instructions .instruction-merged__rich-text *{max-width:100%}.project-detail-page__instructions .instruction-merged__rich-text img{max-width:100%;border-radius:6px;margin:4px 0;display:block}.project-detail-page__instructions .instruction-merged__rich-text table{width:100%;border-collapse:collapse;margin:8px 0;font-size:14px}.project-detail-page__instructions .instruction-merged__rich-text table th,.project-detail-page__instructions .instruction-merged__rich-text table td{border:1px solid #e8e2d8;padding:6px 8px;text-align:left}.project-detail-page__instructions .instruction-merged__rich-text table th{background:#f5f2ee;font-weight:600}.project-detail-page__instructions .instruction-merged__rich-text ul,.project-detail-page__instructions .instruction-merged__rich-text ol{margin:8px 0;padding-left:24px}.project-detail-page__instructions .instruction-merged__rich-text li{margin:4px 0}.project-detail-page__instructions .instruction-merged__rich-text p{margin:8px 0}.project-detail-page__instructions .instruction-merged__rich-text p:first-child{margin-top:0}.project-detail-page__instructions .instruction-merged__rich-text p:last-child{margin-bottom:0}.project-detail-page__instructions .instruction-merged__rich-text h1,.project-detail-page__instructions .instruction-merged__rich-text h2,.project-detail-page__instructions .instruction-merged__rich-text h3,.project-detail-page__instructions .instruction-merged__rich-text h4{margin:12px 0 8px;font-weight:600}.project-detail-page__instructions .instruction-merged__rich-text blockquote{margin:8px 0;padding:8px 12px;border-left:3px solid #e07a5f;background:#f5f2ee;color:#5a5a5a}.project-detail-page__instructions .instruction-merged__note{margin-top:8px;padding:10px 14px;background:#fef3c7;border-radius:8px;font-size:14px;color:#5a5a5a;display:flex;gap:6px;align-items:flex-start}.project-detail-page__instructions .instruction-merged__note .tip-icon{flex-shrink:0;width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23b45309' stroke-width='2'%3E%3Cpath d='M9.663 17h4.673M12 3v1m6.364 1.636l-.707.707M21 12h-1M4 12H3m3.343-5.657l-.707-.707m2.828 9.9a5 5 0 117.072 0l-.548.547A3.374 3.374 0 0014 18.469V19a2 2 0 11-4 0v-.531c0-.895-.356-1.754-.988-2.386l-.548-.547z'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;background-position:center}.project-detail-page__instructions .size-comparison{margin-top:12px;padding:12px;background:#f5f2ee;border-radius:8px}.project-detail-page__instructions .size-comparison__title{font-size:14px;font-weight:500;color:#4a3728;margin-bottom:8px}.project-detail-page__instructions .size-comparison__row{display:flex;justify-content:space-between;font-size:14px;padding:4px 0;border-bottom:1px solid #f0ebe4}.project-detail-page__instructions .size-comparison__row:last-child{border-bottom:none}.project-detail-page__instructions .size-comparison__size{color:#4a3728;font-weight:500}.project-detail-page__instructions .size-comparison__value{color:#5a5a5a;text-align:right}.project-detail-page__instructions .instruction-image-section{margin-top:12px}.project-detail-page__instructions .instruction-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.project-detail-page__instructions .instruction-image-item{aspect-ratio:1/1;border-radius:8px;overflow:hidden;background:#f0ebe4}.project-detail-page__instructions .instruction-image-item img{width:100%;height:100%;object-fit:cover}.project-detail-page__sessions{max-width:960px;margin:0 auto}.project-detail-page__sessions .sessions-empty{padding:16px;text-align:center;font-size:14px;color:#5a5a5a;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.project-detail-page__sessions .sessions-list{display:flex;flex-direction:column;gap:8px}.project-detail-page__sessions .session-item{display:flex;gap:12px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:16px}.project-detail-page__sessions .session-item__timeline{display:flex;flex-direction:column;align-items:center;width:16px}.project-detail-page__sessions .session-item__dot{width:12px;height:12px;background:#e07a5f;border-radius:50%;flex-shrink:0}.project-detail-page__sessions .session-item__line{flex:1;width:2px;background:#f0ebe4;margin:4px 0}.project-detail-page__sessions .session-item__content{flex:1}.project-detail-page__sessions .session-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;cursor:pointer}.project-detail-page__sessions .session-item__header-left{display:flex;align-items:center;gap:8px}.project-detail-page__sessions .session-item__date{font-size:15px;color:#5a5a5a;font-weight:500}.project-detail-page__sessions .session-item__time{font-size:14px;color:#e07a5f;background:#e07a5f1a;padding:2px 8px;border-radius:8px}.project-detail-page__sessions .session-item__arrow{color:#5a5a5a;transition:transform .2s ease;display:flex;align-items:center}.project-detail-page__sessions .session-item__arrow.is-expanded{transform:rotate(180deg)}.project-detail-page__sessions .session-item__step{font-size:15px;color:#3d3d3d;margin-bottom:4px}.project-detail-page__sessions .session-item__preview{display:flex;align-items:center;gap:4px;margin-top:8px}.project-detail-page__sessions .session-item__thumb{width:40px;height:40px;object-fit:cover;border-radius:8px;border:1.5px solid #f0ebe4}.project-detail-page__sessions .session-item__more{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f0ebe4;color:#5a5a5a;font-size:12px;border-radius:8px}.project-detail-page__sessions .session-item__logs{margin-top:12px;display:flex;flex-direction:column;gap:8px}.project-detail-page__sessions .session-log-item{background:#f5f2ee;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:4px}.project-detail-page__sessions .session-log-item__time{font-size:12px;color:#a8a29e;font-weight:500}.project-detail-page__sessions .session-log-item__photo{width:100%;max-height:240px;object-fit:cover;border-radius:8px}.project-detail-page__sessions .session-log-item__text{font-size:14px;color:#3d3d3d;line-height:1.4;margin:0}.project-detail-page__bottom-spacer{height:100px}.timer-bar{position:fixed;left:0;right:0;bottom:0;z-index:110;background:#fffefc;border-top:2px solid #4a3728;box-shadow:0 -4px 12px #4a372814;padding:12px 24px}.timer-bar__main{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.timer-bar__time{font-size:28px;font-weight:700;color:#2c2c2c;font-variant-numeric:tabular-nums;letter-spacing:.03em;min-width:100px}.timer-bar__time.is-running{color:#e07a5f}.timer-bar__controls{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end}.timer-bar__btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border:1.5px solid #4a3728;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;min-height:40px;min-width:80px}.timer-bar__btn:hover{opacity:.9}.timer-bar__btn--start,.timer-bar__btn--resume{background:#e07a5f;border-color:#e07a5f;color:#fff;padding:12px 22px}.timer-bar__btn--start:hover,.timer-bar__btn--resume:hover{background:#c96a52;border-color:#c96a52}.timer-bar__btn--pause{background:#f59e0b;border-color:#f59e0b;color:#fff;padding:12px 22px}.timer-bar__btn--pause:hover{background:#d97706;border-color:#d97706}.timer-bar__btn--stop{background:#fffefc;color:#4a3728}.timer-bar__btn--stop:hover{background:#4a3728;color:#fffefc}.log-photo-area{margin-bottom:12px}.log-photo-upload{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:1.5px dashed #e8e2d8;border-radius:8px;color:#5a5a5a;font-size:14px;cursor:pointer;transition:all .2s ease}.log-photo-upload:hover{border-color:#e07a5f;color:#e07a5f;background:#e07a5f0d}.log-photo-upload input{display:none}.log-photo-preview{position:relative;width:100%;max-height:240px;border-radius:8px;overflow:hidden}.log-photo-preview img{width:100%;height:100%;object-fit:cover}.log-photo-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#00000080;color:#fff;cursor:pointer}.note-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.note-modal__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#4a372880;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.note-modal__content{position:relative;width:100%;max-width:640px;background:#fffefc;border-radius:16px 16px 0 0;border-top:2px solid #4a3728;padding:24px;animation:slideUp .3s ease}.note-modal__content--compact{padding:24px}.note-modal__content h3{font-size:18px;font-weight:600;color:#2c2c2c;margin-bottom:16px;text-align:center}.note-modal__actions{display:flex;gap:12px}.note-modal__actions button{flex:1;padding:12px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.note-modal__actions button:hover{opacity:.9}.note-modal__actions .btn-secondary{background:#f0ebe4;color:#4a3728}.note-modal__actions .btn-secondary:hover{background:#e8e2d8}.note-modal__actions .btn-primary{background:#e07a5f;color:#fff}.note-modal__actions .btn-primary:hover{background:#c96a52}.confirm-hint{font-size:14px;color:#5a5a5a;text-align:center;margin-bottom:16px;line-height:1.5}.end-log-form{margin-bottom:16px}.end-log-form textarea{width:100%;padding:12px;border:1.5px solid #f0ebe4;border-radius:8px;font-size:14px;color:#3d3d3d;resize:none;outline:none;margin-bottom:12px;background:#fffefc}.end-log-form textarea:focus{border-color:#e07a5f}.end-log-form textarea::placeholder{color:#a8a29e}@media (max-width: 768px){.project-detail-page__current-step .current-step-hero__nav,.instruction-merged .current-step-hero__nav{gap:6px}.project-detail-page__current-step .step-nav-btn,.instruction-merged .step-nav-btn{padding:6px 10px;font-size:12px;min-width:auto}.project-detail-page__current-step .step-dots,.instruction-merged .step-dots{gap:4px}.project-detail-page__current-step .step-dot,.instruction-merged .step-dot{width:6px;height:6px}}@media (max-width: 480px){.project-detail-page__current-step{padding:0 12px 16px}.project-detail-page__current-step .current-step-hero__nav,.instruction-merged .current-step-hero__nav{gap:4px;margin-top:16px;padding-top:12px}.project-detail-page__current-step .step-nav-btn,.instruction-merged .step-nav-btn{padding:4px 8px;font-size:11px;min-width:auto}.project-detail-page__current-step .step-dots,.instruction-merged .step-dots{gap:3px}.project-detail-page__current-step .step-dot,.instruction-merged .step-dot{width:5px;height:5px}.project-detail-page__current-step .step-dots-more,.instruction-merged .step-dots-more{font-size:10px}.project-detail-page__instructions .instruction-merged{padding:10px}.project-detail-page__instructions .instruction-merged .current-step-hero{padding:8px;margin:-4px}}.knit-assistant-page{display:flex;flex-direction:column;min-height:calc(100vh - var(--nav-height));max-width:960px;margin:0 auto;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;color:#3d3d3d}.ka-header{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid #4a3728;box-shadow:0 2px 8px #4a372814;z-index:20;flex-shrink:0}.ka-header__back{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;font-size:14px;color:#4a3728;font-weight:600;transition:all .2s}.ka-header__back:hover{background:#4a3728;color:#fffefc}.ka-header__title{font-size:17px;font-weight:700;color:#2c2c2c;margin:0;letter-spacing:.3px;flex:1;text-align:center;padding:0 20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ka-header__meta{display:flex;gap:10px}.ka-header__chip{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;font-size:13px;color:#4a3728;cursor:pointer;transition:all .2s;font-weight:600}.ka-header__chip:hover{background:#4a3728;color:#fffefc}.ka-header__chip.is-active{border-color:#e07a5f;background:#fff5f2;color:#e07a5f}.ka-params-panel{background:#fffefc;border-bottom:2px solid #4a3728;padding:18px 28px;display:flex;gap:32px;flex-wrap:wrap;animation:slideDown .25s ease;flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ka-params-panel__row{display:flex;flex-direction:column;gap:8px}.ka-params-panel__label{font-size:11px;color:#9e9b96;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.ka-params-panel__chips{display:flex;gap:8px}.ka-params-panel__control{display:flex;align-items:center;gap:10px}.ka-params-panel__value{font-size:15px;font-weight:700;color:#e07a5f;min-width:110px;text-align:center;font-variant-numeric:tabular-nums}.ka-params-panel__base{font-size:11px;color:#b5b2ad}.ka-chip{padding:7px 16px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s;color:#4a3728;font-weight:600}.ka-chip.is-active{background:#4a3728;color:#fffefc;box-shadow:2px 2px #4a372833}.ka-chip:hover:not(.is-active){background:#faf8f5}.ka-btn-sm{width:32px;height:32px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#4a3728;font-weight:600}.ka-btn-sm:hover{background:#4a3728;color:#fffefc}.ka-body{display:flex;flex:1}.ka-sidebar{width:280px;background:#fffefc;border-right:2px solid #4a3728;padding:20px;flex-shrink:0}.ka-sidebar__title{font-size:13px;font-weight:700;color:#4a3728;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid #4a3728;text-transform:uppercase;letter-spacing:1px}.ka-step-tree__section{margin-bottom:18px}.ka-step-tree__section-name{font-size:11px;font-weight:700;color:#9e9b96;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;padding-left:4px}.ka-step-tree__step{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;color:#555;transition:all .15s;margin-bottom:3px;position:relative;border:1.5px solid transparent}.ka-step-tree__step:hover{background:#faf8f5;border-color:#e8e5e0}.ka-step-tree__step.is-current{background:#fff5f2;border-color:#e07a5f;color:#c96a52;font-weight:600}.ka-step-tree__step.is-current .ka-step-tree__dot{background:#e07a5f;box-shadow:0 0 0 3px #e07a5f33}.ka-step-tree__step.is-done{color:#9e9b96}.ka-step-tree__step.is-done .ka-step-tree__dot{background:#2d8a5e}.ka-step-tree__step.is-done .ka-step-tree__text{text-decoration:line-through;text-decoration-color:#c4c1bb;text-decoration-thickness:1.5px}.ka-step-tree__dot{width:9px;height:9px;border-radius:50%;background:#ddd9d3;flex-shrink:0;transition:all .2s}.ka-step-tree__text{flex:1;line-height:1.4}.ka-step-tree__badge{font-size:10px;color:#b5b2ad;background:#f5f3f0;padding:2px 7px;border-radius:5px;font-weight:500}.ka-main{flex:1;display:flex;flex-direction:column;padding:28px 40px 100px;gap:20px}.ka-status-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#fffefc;border-radius:10px;box-shadow:4px 4px #4a372814;border:2px solid #4a3728}.ka-status-bar__step{display:flex;align-items:center;gap:10px;font-size:14px}.ka-status-bar__section{font-weight:700;color:#e07a5f;font-size:14px}.ka-status-bar__divider{color:#d4cfc7;font-weight:300}.ka-status-bar__title{color:#4a4a4a;font-weight:500}.ka-status-bar__progress{font-size:13px;color:#8a8a8a;font-weight:500;background:#f5f3f0;padding:6px 14px;border-radius:20px}.ka-row-view{display:flex;flex-direction:column;justify-content:center;background:#fffefc;border-radius:12px;box-shadow:4px 4px #4a372814;border:2px solid #4a3728;padding:24px 28px;min-height:160px}.ka-row-view__alert{background:#fff5f2;border:1.5px solid #e07a5f;border-radius:10px;padding:14px 18px;margin-bottom:24px;font-size:14px;color:#c96a52;display:flex;align-items:center;gap:10px;font-weight:600;flex-shrink:0}.ka-row-view__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-shrink:0}.ka-row-view__badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 18px;background:#4a3728;color:#fffefc;font-size:15px;font-weight:700;border-radius:8px;letter-spacing:.5px;box-shadow:2px 2px #4a372833}.ka-row-view__fraction{font-size:14px;color:#b5b2ad;font-weight:500;font-variant-numeric:tabular-nums}.ka-row-view__instruction{font-size:15px;line-height:1.75;color:#4a4a4a}.ka-row-view__instruction strong,.ka-row-view__instruction b{color:#e07a5f;font-weight:700}.ka-row-view__instruction--fallback{color:#9e9b96;font-style:italic;font-size:15px}.ka-row-view__step-note{margin-bottom:24px;padding-bottom:24px;border-bottom:1px dashed #e8e5e0}.ka-row-view__step-note-label{font-size:12px;color:#b5b2ad;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;font-weight:700}.ka-row-view__step-note-text{font-size:15px;color:#4a4a4a;line-height:1.75}.ka-rich-text{line-height:1.7;word-break:break-word;color:#3d3d3d;white-space:pre-wrap}.ka-rich-text h1,.ka-rich-text h2,.ka-rich-text h3,.ka-rich-text h4,.ka-rich-text h5,.ka-rich-text h6{margin:.6em 0 .4em;color:#2c2c2c;font-weight:700;line-height:1.4}.ka-rich-text h1{font-size:1.4em}.ka-rich-text h2{font-size:1.25em}.ka-rich-text h3{font-size:1.1em}.ka-rich-text p{margin:.5em 0!important;line-height:1.7}.ka-rich-text ul,.ka-rich-text ol{margin:.5em 0;padding-left:1.4em}.ka-rich-text li{margin:.25em 0;line-height:1.7}.ka-rich-text strong,.ka-rich-text b{color:#e07a5f;font-weight:700}.ka-rich-text em,.ka-rich-text i{font-style:italic;color:#6b6b6b}.ka-rich-text blockquote{margin:.6em 0;padding:.6em 1em;border-left:4px solid #e07a5f;background:#fff5f2;border-radius:0 8px 8px 0;color:#5a5a5a}.ka-rich-text img{max-width:100%;border-radius:8px;margin:.5em 0;display:block}.ka-rich-text a{color:#e07a5f;text-decoration:underline}.ka-rich-text pre,.ka-rich-text code{font-family:SF Mono,Monaco,Cascadia Code,monospace;background:#f2f0ec;border-radius:4px;padding:.15em .4em;font-size:.9em}.ka-rich-text pre{padding:.8em 1em;overflow-x:auto}.ka-rich-text pre code{background:transparent;padding:0}.ka-rich-text table{width:100%;border-collapse:collapse;margin:.6em 0}.ka-rich-text table th,.ka-rich-text table td{border:1px solid #e8e5e0;padding:8px 12px;text-align:left}.ka-rich-text table th{background:#f5f3ef;font-weight:600}.ka-footer{display:flex;align-items:center;gap:20px;padding:18px 28px;background:#fffefc;border-radius:12px;box-shadow:4px 4px #4a372814;border:2px solid #4a3728;flex-shrink:0}.ka-nav-btn{display:flex;align-items:center;gap:8px;padding:13px 22px;border:1.5px solid #4a3728;background:#fffefc;border-radius:10px;font-size:14px;color:#4a3728;cursor:pointer;transition:all .2s;font-weight:600}.ka-nav-btn:hover:not(.is-disabled){background:#4a3728;color:#fffefc}.ka-nav-btn.is-disabled{opacity:.35;cursor:not-allowed}.ka-nav-btn--primary{background:#e07a5f;border-color:#e07a5f;color:#fff}.ka-nav-btn--primary:hover{background:#c96a52;border-color:#c96a52}.ka-progress{flex:1;display:flex;flex-direction:column;gap:8px}.ka-progress__track{height:8px;background:#f0eeeb;border-radius:4px;overflow:hidden;border:1px solid #e8e5e0}.ka-progress__fill{height:100%;background:linear-gradient(90deg,#e07a5f,#f0947a);border-radius:4px;transition:width .35s cubic-bezier(.4,0,.2,1)}.ka-progress__text{font-size:12px;color:#9e9b96;text-align:center;font-weight:500;font-variant-numeric:tabular-nums}.ka-quick-log{background:#fffefc;border-radius:12px;box-shadow:4px 4px #4a372814;border:2px solid #4a3728;overflow:hidden}.ka-quick-log__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;cursor:pointer;transition:background .2s}.ka-quick-log__header:hover{background:#faf8f5}.ka-quick-log__header-left{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#4a3728}.ka-quick-log__badge{padding:2px 8px;background:#e07a5f;color:#fff;border-radius:999px;font-size:12px;font-weight:700}.ka-quick-log__arrow{color:#9e9b96;transition:transform .2s}.ka-quick-log__arrow.is-expanded{transform:rotate(180deg)}.ka-quick-log__body{padding:0 20px 16px}.ka-quick-log__submit{width:100%;padding:12px;background:#4a3728;color:#fffefc;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px;transition:background .2s}.ka-quick-log__submit:hover{background:#3a2a1e}.ka-quick-log__preview{padding:12px 20px;display:flex;flex-direction:column;gap:8px}.ka-quick-log__preview-item{display:flex;align-items:center;gap:10px}.ka-quick-log__preview-thumb{width:40px;height:40px;border-radius:6px;object-fit:cover}.ka-quick-log__preview-text{font-size:13px;color:#6a6a6a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ka-quick-log__preview-more{font-size:12px;color:#9e9b96}.ka-log-textarea{width:100%;min-height:80px;padding:12px;border:1.5px solid #e8e5e0;border-radius:8px;background:#faf8f5;font-size:14px;color:#3d3d3d;resize:vertical;outline:none}.ka-log-textarea:focus{border-color:#e07a5f}.ka-log-photo-area{margin-top:12px}.ka-log-photo-upload{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;border:2px dashed #e8e5e0;border-radius:8px;cursor:pointer;font-size:13px;color:#9e9b96;transition:border-color .2s}.ka-log-photo-upload:hover{border-color:#e07a5f}.ka-log-photo-upload input{display:none}.ka-log-photo-preview{position:relative;width:100px;height:100px;border-radius:8px;overflow:hidden}.ka-log-photo-preview img{width:100%;height:100%;object-fit:cover}.ka-log-photo-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#00000080;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.ka-timer-bar{position:fixed;bottom:0;left:0;right:0;background:#fffefc;border-top:2px solid #4a3728;padding:12px 28px;z-index:50;max-width:960px;margin:0 auto}.ka-timer-bar__main{display:flex;align-items:center;justify-content:space-between}.ka-timer-bar__time{font-size:28px;font-weight:700;color:#4a3728;font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,monospace}.ka-timer-bar__time.is-running{color:#e07a5f}.ka-timer-bar__controls{display:flex;gap:10px}.ka-timer-bar__btn{display:flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all .2s}.ka-timer-bar__btn--start{background:#4a3728;color:#fffefc}.ka-timer-bar__btn--start:hover{background:#3a2a1e}.ka-timer-bar__btn--pause{background:#f5a623;color:#fff}.ka-timer-bar__btn--pause:hover{background:#e09520}.ka-timer-bar__btn--resume{background:#4a3728;color:#fffefc}.ka-timer-bar__btn--resume:hover{background:#3a2a1e}.ka-timer-bar__btn--stop{background:#fffefc;color:#4a3728;border-color:#4a3728}.ka-timer-bar__btn--stop:hover{background:#4a3728;color:#fffefc}.ka-timer-bar__btn--log{background:#fffefc;color:#4a3728;border-color:#4a3728}.ka-timer-bar__btn--log:hover{background:#4a3728;color:#fffefc}.ka-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}@media (min-width: 769px){.ka-modal{align-items:center}}.ka-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080}.ka-modal__content{position:relative;background:#fffefc;border-radius:16px 16px 0 0;padding:24px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto}@media (min-width: 769px){.ka-modal__content{border-radius:16px}}.ka-modal__title{font-size:18px;font-weight:700;color:#2c2c2c;margin-bottom:12px}.ka-modal__hint{font-size:13px;color:#9e9b96;margin-bottom:16px}.ka-modal__form{margin-bottom:20px}.ka-modal__actions{display:flex;gap:12px}.ka-modal__btn{flex:1;padding:12px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:all .2s}.ka-modal__btn--secondary{background:#f5f3f0;color:#6a6a6a}.ka-modal__btn--secondary:hover{background:#e8e5e0}.ka-modal__btn--primary{background:#e07a5f;color:#fff}.ka-modal__btn--primary:hover{background:#c96a52}@media (max-width: 768px){.ka-sidebar{display:none}.ka-main{padding:16px 20px 100px}.ka-row-view{padding:24px 20px;border-radius:10px}.ka-row-view__instruction{font-size:20px}.ka-row-view__header{margin-bottom:20px}.ka-row-view__badge{padding:6px 14px;font-size:13px}.ka-footer{flex-wrap:wrap;gap:12px;padding:14px 18px}.ka-nav-btn{flex:1;justify-content:center;padding:12px 16px}.ka-header{padding:10px 16px;flex-wrap:wrap;gap:8px}.ka-header__title{font-size:15px;order:3;flex-basis:100%;text-align:left;padding:0}.ka-timer-bar{padding:10px 16px}.ka-timer-bar__time{font-size:22px}.ka-timer-bar__btn{padding:8px 12px;font-size:12px}}.mine-page{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding:0 20px 40px}.mine-page__header-bg{position:relative;height:120px;overflow:hidden;background:#fffefc;border-bottom:2px solid #4a3728;margin:0 -20px 24px;padding:0 20px}.mine-page__header-bg .header-bg__gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px}.mine-page__user-card{position:relative;z-index:2;max-width:800px;margin:0 auto 24px;padding:24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.mine-page__user-card .user-info{display:flex;align-items:center;gap:16px}.mine-page__user-card .user-info__avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid #4a3728;box-shadow:4px 4px #4a372814}.mine-page__user-card .user-info__avatar--fallback{display:flex;align-items:center;justify-content:center;background:#e8e2d8;color:#5a5a5a;box-sizing:border-box}.mine-page__user-card .user-info__content{flex:1}.mine-page__user-card .user-info__name{font-size:22px;font-weight:700;color:#4a3728;margin-bottom:6px;cursor:pointer}.mine-page__user-card .user-info__hint{font-size:14px;color:#5a5a5a}.mine-page__user-card .user-info__level{display:flex;align-items:center;gap:8px}.mine-page__user-card .user-info__level .level-badge{padding:4px 10px;background:#e07a5f;color:#fff;font-size:12px;font-weight:600;border-radius:8px}.mine-page__user-card .user-info__level .level-name{font-size:14px;color:#5a5a5a}.mine-page__menu-section{max-width:800px;margin:0 auto 24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;overflow:hidden}.mine-page__menu-section .menu-item{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;cursor:pointer;transition:all .2s ease}.mine-page__menu-section .menu-item:not(:last-child){border-bottom:1px solid #e8e2d8}.mine-page__menu-section .menu-item:hover{background:#faf8f5}.mine-page__menu-section .menu-item:active{background:#f0ebe3}.mine-page__menu-section .menu-item__left{display:flex;align-items:center;gap:12px}.mine-page__menu-section .menu-item__icon{color:#e07a5f}.mine-page__menu-section .menu-item__label{font-size:16px;color:#3d3d3d;font-weight:500}.mine-page__menu-section .menu-item__right{display:flex;align-items:center;gap:8px}.mine-page__menu-section .menu-item__count{font-size:14px;color:#fff;background:#e07a5f;padding:2px 8px;border-radius:8px;font-weight:600}.mine-page__menu-section .menu-item__arrow{color:#5a5a5a}.mine-page__version{text-align:center;padding:16px}.mine-page__version span{font-size:14px;color:#5a5a5a}.to-weave-page{min-height:100%;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px}.to-weave-page__header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fff;border-bottom:2px solid #4a3728}.to-weave-page__header .back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#4a3728;cursor:pointer}.to-weave-page__header h1{font-size:20px;font-weight:600;color:#4a3728}.to-weave-page__header .placeholder{width:36px}.to-weave-page__content{max-width:960px;margin:0 auto;padding:24px}.to-weave-page .to-weave-list{display:flex;flex-direction:column;gap:16px}.to-weave-page .to-weave-card{display:flex;gap:16px;padding:16px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;cursor:pointer}.to-weave-page .to-weave-card__image-wrapper{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0;border:1.5px solid #4a3728}.to-weave-page .to-weave-card__image-wrapper img{width:100%;height:100%;object-fit:cover}.to-weave-page .to-weave-card__category{position:absolute;top:4px;left:4px;padding:2px 8px;background:#4a3728b3;color:#fff;font-size:12px;border-radius:6px}.to-weave-page .to-weave-card__content{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}.to-weave-page .to-weave-card__title{font-size:16px;font-weight:600;color:#2c2c2c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.to-weave-page .to-weave-card__actions{display:flex;justify-content:flex-end;gap:12px}.to-weave-page .to-weave-card__actions .btn-remove{padding:6px 14px;border:1.5px solid #4a3728;background:#fffefc;border-radius:8px;font-size:14px;color:#4a3728;cursor:pointer}.to-weave-page .to-weave-card__actions .btn-remove:hover{background:#4a3728;color:#fffefc}.to-weave-page .to-weave-card__actions .btn-start{padding:6px 14px;border:1.5px solid #e07a5f;background:#e07a5f;border-radius:8px;font-size:14px;color:#fff;cursor:pointer}.to-weave-page .to-weave-card__actions .btn-start:hover{background:#c96a52;border-color:#c96a52}.my-pattern-edit{flex:1;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;display:flex;flex-direction:column}.my-pattern-edit__header{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.my-pattern-edit__header h1{font-size:18px;font-weight:600;color:#2c2c2c}.my-pattern-edit__header .back-btn{background:none;border:2px solid #4a3728;border-radius:8px;padding:6px;color:#4a3728;cursor:pointer;transition:all .2s ease}.my-pattern-edit__header .back-btn:hover{background:#4a3728;color:#fffefc}.my-pattern-edit__header .header-spacer{width:40px}.my-pattern-edit__form{flex:1;padding:24px 28px;overflow-y:auto;max-width:960px;margin:0 auto;width:100%}.my-pattern-edit__form .form-group{margin-bottom:20px}.my-pattern-edit__form .form-group label{display:block;font-size:15px;color:#4a3728;margin-bottom:8px;font-weight:500}.my-pattern-edit__form .form-group label .required{color:#c62828}.my-pattern-edit__form .form-group input,.my-pattern-edit__form .form-group textarea{width:100%;padding:10px 14px;border:1.5px solid #e8e2d8;border-radius:8px;font-size:15px;background:#fffefc;color:#2c2c2c;outline:none;transition:border-color .2s ease}.my-pattern-edit__form .form-group input:focus,.my-pattern-edit__form .form-group textarea:focus{border-color:#4a3728}.my-pattern-edit__form .form-group input::placeholder,.my-pattern-edit__form .form-group textarea::placeholder{color:#9a8e80}.my-pattern-edit__form .form-group textarea{resize:vertical}.my-pattern-edit__form .form-group--row{display:flex;align-items:center;justify-content:space-between;padding:14px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.my-pattern-edit__form .form-group--row label{margin-bottom:0}.my-pattern-edit__form .image-upload{width:160px;height:160px;border-radius:12px;border:2px dashed #e8e2d8;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#fffefc;cursor:pointer;transition:border-color .2s ease}.my-pattern-edit__form .image-upload:hover{border-color:#4a3728}.my-pattern-edit__form .image-upload img{width:100%;height:100%;object-fit:cover}.my-pattern-edit__form .image-upload__placeholder{display:flex;flex-direction:column;align-items:center;color:#9a8e80;font-size:13px;gap:6px}.my-pattern-edit__form .instruction-image-grid{display:flex;flex-wrap:wrap;gap:12px}.my-pattern-edit__form .instruction-image-thumb{position:relative;width:120px;height:120px;border-radius:12px;overflow:hidden;background:#e8e2d8;border:2px solid #4a3728;box-shadow:4px 4px #4a372814}.my-pattern-edit__form .instruction-image-thumb img{width:100%;height:100%;object-fit:cover}.my-pattern-edit__form .instruction-image-thumb .remove-image-btn{position:absolute;top:6px;right:6px;width:24px;height:24px;border:none;border-radius:6px;background:#e07a5f;color:#fffefc;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:background .2s ease}.my-pattern-edit__form .instruction-image-thumb .remove-image-btn:hover{background:#c96a52}.my-pattern-edit__form .instruction-image-upload{width:120px;height:120px;border-radius:12px;border:2px dashed #e8e2d8;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9a8e80;font-size:13px;gap:6px;background:#fffefc;cursor:pointer;transition:border-color .2s ease}.my-pattern-edit__form .instruction-image-upload:hover{border-color:#4a3728}.my-pattern-edit__form .toggle{width:48px;height:26px;border-radius:8px;background:#e8e2d8;border:none;position:relative;cursor:pointer;transition:background .2s}.my-pattern-edit__form .toggle:disabled{opacity:.6;cursor:not-allowed}.my-pattern-edit__form .toggle.is-active{background:#e07a5f}.my-pattern-edit__form .toggle__knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:6px;background:#fffefc;transition:transform .2s}.my-pattern-edit__form .toggle.is-active .toggle__knob{transform:translate(22px)}.my-pattern-edit__form .status-hint{font-size:13px;margin-left:8px;padding:4px 10px;border-radius:8px;border:1.5px solid #e8e2d8}.my-pattern-edit__form .status-hint.pending{color:#b8860b;background:#faf8f5}.my-pattern-edit__form .status-hint.approved{color:#2e7d32;background:#faf8f5}.my-pattern-edit__form .form-hint{font-size:13px;color:#9a8e80;margin-top:-12px;margin-bottom:12px;line-height:1.5}.my-pattern-edit__form .form-hint.error{color:#c62828}.my-pattern-edit__footer{padding:14px 28px 24px;background:#fffefc;border-top:2px solid #4a3728;max-width:960px;margin:0 auto;width:100%}.my-pattern-edit__footer .save-btn{width:100%;padding:12px;border:1.5px solid #e07a5f;border-radius:8px;background:#e07a5f;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.my-pattern-edit__footer .save-btn:hover{background:#c96a52;border-color:#c96a52}.my-pattern-detail{flex:1;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;display:flex;flex-direction:column}.my-pattern-detail__header{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.my-pattern-detail__header h1{font-size:18px;font-weight:600;color:#2c2c2c}.my-pattern-detail__header .back-btn,.my-pattern-detail__header .edit-btn{background:none;border:2px solid #4a3728;border-radius:8px;padding:6px;color:#4a3728;cursor:pointer;transition:all .2s ease}.my-pattern-detail__header .back-btn:hover,.my-pattern-detail__header .edit-btn:hover{background:#4a3728;color:#fffefc}.my-pattern-detail__content{flex:1;overflow-y:auto;max-width:960px;margin:0 auto;width:100%;padding:24px 28px}.my-pattern-detail__content .cover-image{width:100%;aspect-ratio:4/3;background:#e8e2d8;border:2px solid #4a3728;border-radius:12px;overflow:hidden;box-shadow:4px 4px #4a372814}.my-pattern-detail__content .cover-image img{width:100%;height:100%;object-fit:cover}.my-pattern-detail__content .info-section{padding:20px 24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;margin-top:20px}.my-pattern-detail__content .info-section .pattern-name-row{display:flex;align-items:center;gap:10px;margin-bottom:16px}.my-pattern-detail__content .info-section .pattern-name{font-size:22px;font-weight:600;color:#2c2c2c}.my-pattern-detail__content .info-section .market-status-tag{display:inline-flex;padding:4px 10px;border-radius:8px;font-size:13px;font-weight:500;border:1.5px solid transparent}.my-pattern-detail__content .info-section .market-status-tag--pending{background:#faf8f5;color:#b8860b;border-color:#e8e2d8}.my-pattern-detail__content .info-section .market-status-tag--approved{background:#faf8f5;color:#2e7d32;border-color:#e8e2d8}.my-pattern-detail__content .info-section .market-status-tag--rejected{background:#faf8f5;color:#c62828;border-color:#e8e2d8}.my-pattern-detail__content .info-section .reward-info,.my-pattern-detail__content .info-section .rejected-reason{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 14px;border-radius:8px;font-size:14px;border:1.5px solid #e8e2d8}.my-pattern-detail__content .info-section .reward-info{background:#faf8f5;color:#b8860b}.my-pattern-detail__content .info-section .rejected-reason{background:#faf8f5;color:#c62828}.my-pattern-detail__content .info-section .reward-label,.my-pattern-detail__content .info-section .rejected-label{font-weight:600}.my-pattern-detail__content .info-section .meta-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.my-pattern-detail__content .info-section .meta-list .meta-item{display:flex;font-size:15px}.my-pattern-detail__content .info-section .meta-list .meta-item .meta-label{color:#9a8e80;width:64px;flex-shrink:0;font-weight:500}.my-pattern-detail__content .info-section .meta-list .meta-item .meta-value{color:#3d3d3d}.my-pattern-detail__content .info-section .instruction-section h3{font-size:18px;font-weight:600;color:#2c2c2c;margin-bottom:10px}.my-pattern-detail__content .info-section .instruction-section .instruction-text{font-size:15px;line-height:1.7;color:#5a5a5a;white-space:pre-wrap}.my-pattern-detail__content .info-section .instruction-image-section{margin-top:20px}.my-pattern-detail__content .info-section .instruction-image-section h3{font-size:18px;font-weight:600;color:#2c2c2c;margin-bottom:14px}.my-pattern-detail__content .info-section .instruction-image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.my-pattern-detail__content .info-section .instruction-image-item{aspect-ratio:1/1;border-radius:12px;overflow:hidden;background:#e8e2d8;border:2px solid #4a3728;box-shadow:4px 4px #4a372814}.my-pattern-detail__content .info-section .instruction-image-item img{width:100%;height:100%;object-fit:cover}.my-pattern-detail__footer{display:flex;gap:12px;padding:14px 28px;background:#fffefc;border-top:2px solid #4a3728;max-width:960px;margin:0 auto;width:100%}.my-pattern-detail__footer .btn{flex:1;padding:12px;border:1.5px solid #4a3728;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.my-pattern-detail__footer .btn--secondary{background:#fffefc;color:#4a3728}.my-pattern-detail__footer .btn--secondary:hover{background:#4a3728;color:#fffefc}.my-pattern-detail__footer .btn--primary{background:#e07a5f;border-color:#e07a5f;color:#fff}.my-pattern-detail__footer .btn--primary:hover{background:#c96a52;border-color:#c96a52}@media (max-width: 640px){.my-pattern-detail__content .info-section .instruction-image-grid{grid-template-columns:repeat(2,1fr)}.my-pattern-detail__footer{padding:10px 16px;gap:8px}.my-pattern-detail__footer .btn{padding:10px;font-size:14px}}.my-pattern-list{flex:1;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;display:flex;flex-direction:column}.my-pattern-list__header{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#fffefc;border-bottom:2px solid #4a3728}.my-pattern-list__header h1{font-size:18px;font-weight:600;color:#2c2c2c}.my-pattern-list__header .back-btn{background:none;border:2px solid #4a3728;border-radius:8px;padding:6px;color:#4a3728;cursor:pointer;transition:all .2s ease}.my-pattern-list__header .back-btn:hover{background:#4a3728;color:#fffefc}.my-pattern-list__header .header-spacer{width:40px}.my-pattern-list__content{flex:1;padding:24px 28px;overflow-y:auto;max-width:960px;margin:0 auto;width:100%}.my-pattern-list .add-btn-bar{margin-bottom:20px}.my-pattern-list .add-btn-bar .add-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:#e07a5f;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s ease}.my-pattern-list .add-btn-bar .add-btn:hover{background:#c96a52}.my-pattern-list .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.my-pattern-list .empty-state__icon{color:#c4bbb0;margin-bottom:20px}.my-pattern-list .empty-state__title{font-size:20px;font-weight:600;color:#4a3728;margin-bottom:8px}.my-pattern-list .empty-state__desc{font-size:14px;color:#9a8e80;margin-bottom:28px}.my-pattern-list .empty-state__action{padding:12px 32px;background:#e07a5f;color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s ease}.my-pattern-list .empty-state__action:hover{background:#c96a52}.my-pattern-list .pattern-list{display:flex;flex-direction:column;gap:16px}.my-pattern-list .pattern-card{display:flex;align-items:center;gap:16px;padding:16px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.my-pattern-list .pattern-card:hover{transform:translateY(-2px);box-shadow:6px 6px #4a37281f}.my-pattern-list .pattern-card__thumb{width:88px;height:88px;border-radius:10px;overflow:hidden;flex-shrink:0;background:#e8e2d8;border:1.5px solid #e8e2d8}.my-pattern-list .pattern-card__thumb img{width:100%;height:100%;object-fit:cover}.my-pattern-list .pattern-card__no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9a8e80;font-size:13px}.my-pattern-list .pattern-card__info{flex:1;min-width:0}.my-pattern-list .pattern-card__name-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.my-pattern-list .pattern-card__name{font-size:16px;font-weight:600;color:#2c2c2c;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-pattern-list .pattern-card__tag{display:inline-flex;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:500;border:1.5px solid #e8e2d8;flex-shrink:0}.my-pattern-list .pattern-card__tag.tag--default{background:#faf8f5;color:#9a8e80}.my-pattern-list .pattern-card__tag.tag--warning{background:#faf8f5;color:#b8860b}.my-pattern-list .pattern-card__tag.tag--success{background:#faf8f5;color:#2e7d32}.my-pattern-list .pattern-card__tag.tag--danger{background:#faf8f5;color:#c62828}.my-pattern-list .pattern-card__meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:13px;color:#9a8e80}.my-pattern-list .pattern-card__meta span{white-space:nowrap}.my-pattern-list .pattern-card__actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.my-pattern-list .pattern-card__actions .action-btn{width:32px;height:32px;border:1.5px solid #e8e2d8;border-radius:8px;background:#fffefc;color:#5a5a5a;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:all .2s ease}.my-pattern-list .pattern-card__actions .action-btn:hover{border-color:#4a3728;color:#4a3728}.my-pattern-list .pattern-card__actions .action-btn--danger:hover{border-color:#c62828;color:#c62828}@media (max-width: 640px){.my-pattern-list__header{padding:10px 16px}.my-pattern-list__content{padding:16px}.my-pattern-list .pattern-card{padding:12px;gap:12px}.my-pattern-list .pattern-card__thumb{width:72px;height:72px}.my-pattern-list .pattern-card__actions{flex-direction:row}}.comment-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;flex-direction:column;justify-content:flex-end}.comment-sheet__mask{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006}.comment-sheet__body{position:relative;background:var(--white);border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:70vh;display:flex;flex-direction:column;animation:slideUp .25s ease}.comment-sheet__header{display:flex;align-items:center;justify-content:space-between;padding:.32rem .427rem;border-bottom:1px solid var(--gray-100)}.comment-sheet__title{font-size:.4rem;font-weight:500}.comment-sheet__close{background:none;border:none;color:var(--gray-400)}.comment-sheet__list{flex:1;overflow-y:auto;padding:.213rem .427rem}.comment-sheet__empty{text-align:center;color:var(--gray-400);padding:.64rem 0;font-size:.373rem}.comment-sheet__input-bar{display:flex;gap:.213rem;align-items:center;padding:.267rem .427rem .427rem;padding-bottom:calc(.267rem + env(safe-area-inset-bottom));border-top:1px solid var(--gray-100)}.comment-sheet__input{flex:1;padding:.213rem .32rem;border:1px solid var(--gray-300);border-radius:var(--radius-full);font-size:.373rem}.comment-sheet__send{width:.96rem;height:.96rem;border-radius:50%;border:none;background:var(--primary-500);color:var(--white);display:flex;align-items:center;justify-content:center}.comment-item{display:flex;gap:.267rem;padding:.267rem 0;border-bottom:1px solid var(--gray-50)}.comment-item__avatar{width:.853rem;height:.853rem;border-radius:50%;background:var(--gray-100);flex-shrink:0;background-size:cover}.comment-item__main{flex:1}.comment-item__meta{display:flex;justify-content:space-between;margin-bottom:.107rem}.comment-item__name{font-size:.347rem;color:var(--primary-500);font-weight:500}.comment-item__time{font-size:.32rem;color:var(--gray-400)}.comment-item__content{font-size:.373rem;line-height:1.5;color:var(--gray-900)}.comment-item__delete{font-size:.32rem;color:var(--gray-400);background:none;border:none;padding:0 .107rem}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.weaver-circle{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px;padding-bottom:80px}.weaver-circle__header{position:sticky;top:0;z-index:10;height:56px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#4a3728;border-bottom:2px solid #4a3728}.weaver-circle__feed{padding-top:16px;max-width:960px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px;padding-left:24px;padding-right:24px}.weaver-circle__empty{text-align:center;color:#5a5a5a;padding:48px 24px;font-size:16px}.weaver-circle__fab{position:fixed;right:24px;bottom:24px;width:56px;height:56px;border-radius:12px;border:none;background:#e07a5f;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:4px 4px #4a37281f;z-index:20;cursor:pointer}.weaver-circle__fab:hover{background:#c96a52}.post-card{background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:20px;width:100%;max-width:640px}.post-card.is-highlighted{box-shadow:inset 0 0 0 2px #e07a5f,4px 4px #4a372814}.post-card__header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.post-card__avatar{width:44px;height:44px;border-radius:50%;background:#f0ebe4;flex-shrink:0;background-size:cover;border:1.5px solid #4a3728}.post-card__meta{flex:1}.post-card__name{font-size:16px;font-weight:600;color:#4a3728}.post-card__time{font-size:13px;color:#5a5a5a;margin-top:4px}.post-card__type{color:#e07a5f}.post-card__delete{font-size:13px;color:#5a5a5a;background:none;border:none;cursor:pointer}.post-card__delete:hover{color:#c96a52}.post-card__content{font-size:15px;line-height:1.6;margin-bottom:16px;white-space:pre-wrap;color:#3d3d3d}.post-card__images{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.post-card__images--1 .post-card__img{width:240px;height:240px}.post-card__images--2 .post-card__img{width:calc(50% - 4px);aspect-ratio:1/1}.post-card__images--3 .post-card__img{width:calc(33.33% - 6px);aspect-ratio:1/1}.post-card__img{border-radius:8px;object-fit:cover;background:#f0ebe4;border:1.5px solid #4a3728}.post-card__pattern-tag{display:inline-block;padding:6px 12px;background:#faf8f5;color:#e07a5f;font-size:13px;border-radius:8px;margin-bottom:16px;border:1.5px solid #e07a5f}.post-card__actions{display:flex;gap:24px}.post-card__action{display:flex;align-items:center;gap:6px;font-size:14px;color:#5a5a5a;background:none;border:none;cursor:pointer}.post-card__action.is-liked{color:#e07a5f}.post-card__action:hover{color:#4a3728}.post-card__comments-preview{background:#faf8f5;border-radius:8px;padding:12px 16px;margin-top:16px;border:1.5px solid #e8e2d8}.comment-preview-item{font-size:14px;line-height:1.5;margin-bottom:8px}.comment-preview-item:last-child{margin-bottom:0}.comment-preview-item__name{color:#e07a5f;font-weight:600}.comment-preview-item__content{color:#3d3d3d}.comment-preview-more{font-size:13px;color:#e07a5f;margin-top:8px;cursor:pointer}.comment-preview-more:hover{color:#c96a52}.publish-menu{position:fixed;left:50%;transform:translate(-50%);bottom:0;width:100%;max-width:640px;background:#fffefc;border-radius:12px 12px 0 0;padding:24px;z-index:110;animation:slideUp .25s ease;border-top:2px solid #4a3728;box-shadow:0 -4px #4a372814}.publish-menu__mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#4a372866;z-index:109}.publish-menu__title{font-size:14px;color:#5a5a5a;text-align:center;margin-bottom:16px}.publish-menu__option{padding:14px;text-align:center;font-size:16px;color:#4a3728;border-bottom:1.5px solid #f0ebe4;cursor:pointer}.publish-menu__option:hover{background:#faf8f5}.publish-menu__option:last-of-type{border-bottom:none}.publish-menu__cancel{margin-top:12px;padding:14px;text-align:center;font-size:16px;color:#5a5a5a;cursor:pointer;border:1.5px solid #4a3728;border-radius:8px;background:#fffefc}.publish-menu__cancel:hover{background:#4a3728;color:#fffefc}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.circle-post{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px}.circle-post__header{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 28px;background:#fff;border-bottom:2px solid #4a3728}.circle-post__header h1{font-size:18px;font-weight:600;color:#4a3728}.circle-post__back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#4a3728;cursor:pointer}.circle-post__publish{padding:6px 16px;background:#e07a5f;border:1.5px solid #e07a5f;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.circle-post__publish:hover{background:#c96a52;border-color:#c96a52}.circle-post__body{max-width:640px;margin:24px auto;padding:24px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814}.circle-post__textarea{width:100%;border:1.5px dashed #d4cfc7;border-radius:8px;padding:12px;font-size:15px;line-height:1.6;resize:none;outline:none;background:#fff;color:#3d3d3d}.circle-post__textarea::placeholder{color:#9e9a93}.circle-post__image-section{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.circle-post__image-item{width:100px;height:100px;border-radius:8px;overflow:hidden;position:relative;background:#f0ebe4;border:1.5px solid #4a3728}.circle-post__image-item img{width:100%;height:100%;object-fit:cover}.circle-post__image-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;border:none;background:#4a3728b3;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.circle-post__image-remove:hover{background:#4a3728e6}.circle-post__image-add{width:100px;height:100px;border-radius:8px;border:1.5px dashed #d4cfc7;display:flex;align-items:center;justify-content:center;color:#9e9a93;font-size:28px;background:#fff;cursor:pointer}.circle-post__image-add:hover{border-color:#e07a5f;color:#e07a5f}.circle-post__image-add input{display:none}.circle-post__hint{margin-top:16px;font-size:13px;color:#5a5a5a}.circle-project-picker{min-height:100vh;background:#faf8f5;background-image:radial-gradient(#e8e2d8 1px,transparent 1px);background-size:24px 24px}.circle-project-picker__header{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 28px;background:#fff;border-bottom:2px solid #4a3728}.circle-project-picker__header h1{font-size:18px;font-weight:600;color:#4a3728}.circle-project-picker__header .placeholder{width:36px}.circle-project-picker__header .back-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:#4a3728;cursor:pointer}.circle-project-picker__list{max-width:960px;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:16px}.circle-project-picker .empty-state{text-align:center;color:#5a5a5a;padding:48px 24px;font-size:16px}.circle-project-picker .project-picker-card{display:flex;align-items:center;gap:16px;background:#fffefc;border:2px solid #4a3728;border-radius:12px;box-shadow:4px 4px #4a372814;padding:16px;cursor:pointer}.circle-project-picker .project-picker-card:hover{box-shadow:6px 6px #4a37281a}.circle-project-picker .project-picker-card__img{width:64px;height:64px;border-radius:8px;object-fit:cover;background:#f0ebe4;border:1.5px solid #4a3728}.circle-project-picker .project-picker-card__info{flex:1}.circle-project-picker .project-picker-card__name{font-size:16px;font-weight:600;color:#2c2c2c;margin-bottom:6px}.circle-project-picker .project-picker-card__meta{font-size:13px;color:#5a5a5a}.circle-project-picker .project-picker-card__arrow{color:#4a3728}:root{--nav-height: 64px}.app{min-height:100vh;background:#faf9f7}.app__content{padding-top:var(--nav-height);min-height:100vh;display:flex;flex-direction:column}.app-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid #f0eeeb;height:64px}.app-nav__container{max-width:1280px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}.app-nav__brand{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.app-nav__logo{font-size:22px;font-weight:700;color:#c9a96e;letter-spacing:1px}.app-nav__links{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.app-nav__link{padding:8px 18px;border-radius:8px;font-size:15px;font-weight:500;color:#5a5a5a;text-decoration:none;transition:all .2s}.app-nav__link:hover{color:#3d3d3d;background:#f5f3f0}.app-nav__link.is-active{color:#c9a96e;background:#fdf8f0;font-weight:600}.app-nav__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.app-nav__search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#f5f3f0;border-radius:10px;width:220px;transition:all .2s;color:#9e9b96}.app-nav__search:focus-within{background:#fff;box-shadow:0 0 0 2px #c9a96e33}.app-nav__search input{flex:1;border:none;background:transparent;font-size:14px;color:#3d3d3d;outline:none}.app-nav__search input::placeholder{color:#b5b2ad}.app-nav__user{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f5f3f0;color:#5a5a5a;cursor:pointer;transition:all .2s;text-decoration:none}.app-nav__user:hover{background:#ebe8e3;color:#3d3d3d}@media (max-width: 768px){:root{--nav-height: 56px}.app-nav{height:var(--nav-height)}.app-nav__container{padding:0 16px}.app-nav__logo{font-size:18px}.app-nav__links{gap:0}.app-nav__link{padding:6px 10px;font-size:13px}.app-nav__search{display:none}}:root{--primary-50: #FFF0F0;--primary-100: #FFE0E0;--primary-200: #FFC1C1;--primary-300: #FF9B9B;--primary-400: #FF7A7A;--primary-500: #FF6B6B;--primary-600: #E85A5A;--primary-700: #D44A4A;--primary-800: #B03A3A;--primary-900: #8B2E2E;--secondary-50: #FBF7F4;--secondary-100: #F5EDE6;--secondary-200: #E8D9CC;--secondary-300: #D9C2B0;--secondary-400: #D4A574;--secondary-500: #C9946A;--secondary-600: #B8835A;--secondary-700: #A0724A;--secondary-800: #88613D;--secondary-900: #6F4F30;--gray-50: #FAFAFA;--gray-100: #F5F5F5;--gray-200: #E5E5E5;--gray-300: #D4D4D4;--gray-400: #A3A3A3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--gray-900: #171717;--success-500: #10B981;--warning-500: #F59E0B;--error-500: #EF4444;--info-500: #3B82F6;--white: #FFFFFF;--black: #000000;--font-xs: 20px;--font-sm: 24px;--font-base: 28px;--font-lg: 32px;--font-xl: 36px;--font-2xl: 40px;--font-3xl: 48px;--space-1: 8px;--space-2: 16px;--space-3: 24px;--space-4: 32px;--space-5: 40px;--space-6: 48px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--gradient-primary: linear-gradient(135deg, var(--primary-500) 0%, var(--primary-400) 100%);--gradient-secondary: linear-gradient(135deg, var(--secondary-400) 0%, var(--secondary-500) 100%)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,PingFang SC,Microsoft YaHei,sans-serif;font-size:15px;line-height:1.6;color:#3d3d3d;background-color:#faf9f7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}.page-container{min-height:100vh;background-color:#faf9f7}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multi-ellipsis-2{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.multi-ellipsis-3{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #0000000a;border:1px solid #f0eeeb;overflow:hidden}.btn{display:flex;align-items:center;justify-content:center;height:44px;padding:0 24px;border-radius:10px;font-size:15px;font-weight:600;transition:all .2s ease;cursor:pointer;border:none;outline:none}.btn--primary{background:#c9a96e;color:#fff;box-shadow:0 2px 10px #c9a96e4d}.btn--primary:hover{background:#b8975d}.btn--secondary{background:#f5f3f0;color:#5a5a5a}.btn--secondary:hover{background:#ebe8e3}.btn--outline{background:transparent;border:1px solid #c9a96e;color:#c9a96e}.btn--outline:hover{background:#fdf8f0}.btn:disabled{opacity:.5;cursor:not-allowed}.tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.tag--primary{background:#fdf8f0;color:#a67c3b}.tag--secondary{background:#f5f3f0;color:#5a5a5a}.tag--success{background:#10b9811a;color:#10b981}.tag--warning{background:#f59e0b1a;color:#f59e0b}.tag--gray{background:#f5f3f0;color:#6b6b6b}.skeleton{background:linear-gradient(90deg,#ece8e3 25%,#f5f3f0,#ece8e3 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.toast-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none}.toast{padding:14px 24px;background:#000c;color:#fff;border-radius:12px;font-size:14px;animation:fadeInUp .3s ease;white-space:nowrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s ease}.empty-state{display:flex;align-items:center;justify-content:center;flex-direction:column;padding:80px 40px}.empty-state__icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state__title{font-size:16px;font-weight:500;color:#6b6b6b;margin-bottom:8px}.empty-state__desc{font-size:14px;color:#9e9b96;text-align:center;margin-bottom:24px}
