*,:before,:after{box-sizing:border-box}body{margin:0}:root{--yellow:#ffb800;--purple:#6c3fc8;--purple-light:#f0e7ff;--purple-dark:#4a2d8e;--facebook:#1877f2;--instagram:#e1306c;--white:#fff;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-600:#52525b;--gray-800:#27272a;--radius:16px;--radius-sm:10px;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{min-height:100vh;color:var(--gray-800);background:linear-gradient(135deg,#fff9e6 0%,#f5eeff 100%);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;line-height:1.5}.app-header{background:linear-gradient(135deg, var(--purple) 0%, #8b5cf6 100%);color:#fff;z-index:100;padding:20px 16px 12px;position:sticky;top:0;box-shadow:0 4px 20px #6c3fc866}.header-content{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.logo-area{align-items:center;gap:12px;display:flex}.logo-icon{filter:drop-shadow(0 2px 4px #0003);font-size:2.2rem;line-height:1}.app-title{color:var(--yellow);letter-spacing:-.5px;text-shadow:0 2px 4px #0003;font-size:1.5rem;font-weight:800;line-height:1.1}.app-subtitle{color:#fffc;font-size:.75rem;font-weight:500}.progress-area{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.progress-bar-wrap{background:#fff3;border-radius:3px;width:80px;height:6px;overflow:hidden}.progress-bar{background:var(--yellow);border-radius:3px;height:100%;transition:width .5s}.progress-label{color:#ffffffd9;font-size:.7rem;font-weight:600}.header-actions{align-items:center;gap:10px;display:flex}.filter-tabs{scrollbar-width:none;-ms-overflow-style:none;flex:1;gap:6px;display:flex;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{color:#fffc;cursor:pointer;white-space:nowrap;background:0 0;border:2px solid #ffffff4d;border-radius:20px;flex-shrink:0;min-height:36px;padding:8px 14px;font-size:.75rem;font-weight:600;transition:all .2s}.filter-tab:active{transform:scale(.95)}.filter-tab.active{background:var(--yellow);border-color:var(--yellow);color:var(--purple-dark)}.legend-toggle{color:#fff;cursor:pointer;white-space:nowrap;background:0 0;border:2px solid #fff6;border-radius:20px;flex-shrink:0;min-height:36px;padding:8px 12px;font-size:.75rem;font-weight:600}.legend-panel{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1f;flex-direction:column;gap:14px;margin-top:12px;padding:14px;display:flex}.platform-legend{flex-wrap:wrap;gap:8px;display:flex}.plat-item{text-align:center;border:2px solid;border-radius:8px;flex-direction:column;align-items:center;gap:2px;min-width:60px;padding:6px 12px;display:flex}.legend-title{color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.7rem;font-weight:700}.legend-items{flex-wrap:wrap;gap:8px;display:flex}.legend-item{background:#ffffff26;border-radius:8px;align-items:center;gap:6px;padding:4px 10px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.8rem;display:flex}.legend-label{color:#ffffffe6;font-size:.7rem;font-weight:500}.calendar-main{flex-direction:column;gap:0;max-width:680px;margin:0 auto;padding:16px;display:flex}.week-section{margin-bottom:8px}.week-summary{border-radius:var(--radius) var(--radius) 0 0;border:2px solid var(--gray-200);background:#fff;border-bottom:none;justify-content:space-between;align-items:center;margin-bottom:0;padding:10px 16px;display:flex}.week-label{color:var(--purple);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:700}.week-counts{gap:6px;display:flex}.wc{border-radius:10px;padding:3px 8px;font-size:.65rem;font-weight:700}.wc.facebook{color:var(--facebook);background:#e7f0ff}.wc.instagram{color:var(--instagram);background:#ffe7f0}.wc.both{background:var(--purple-light);color:var(--purple)}.week-days{flex-direction:column;gap:0;display:flex}.week-days .day-card:last-child{border-radius:0 0 var(--radius) var(--radius)}.week-days.filtered{gap:8px}.week-days.filtered .day-card{border-radius:var(--radius)!important}.day-card{border:2px solid var(--gray-200);background:#fff;border-top:none;transition:all .2s;overflow:hidden}.day-card:first-child{border-top:2px solid var(--gray-200)}.week-days .day-card:first-child{border-top:none}.day-card.done{opacity:.6}.day-card.done .day-title{text-decoration:line-through}.day-card.expanded{border-color:var(--platform-color,var(--purple));border-width:2px;border-top:2px solid var(--platform-color,var(--purple));box-shadow:var(--shadow-lg);z-index:1;margin:4px 0;position:relative;border-radius:var(--radius-sm)!important}.day-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;min-height:60px;padding:14px;display:flex}.day-card-header:active{background:var(--gray-50)}.day-number-wrap{flex-direction:column;flex-shrink:0;align-items:center;min-width:46px;display:flex}.day-number{color:var(--purple);font-size:.75rem;font-weight:800;line-height:1}.weekday{color:var(--gray-600);white-space:nowrap;font-size:.6rem;font-weight:500}.day-meta{flex-shrink:0;align-items:center;gap:4px;display:flex}.platform-badge{color:#fff;letter-spacing:.02em;border-radius:6px;padding:3px 7px;font-size:.6rem;font-weight:800}.pillar-dot{border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;display:flex}.post-type-mini{font-size:.9rem}.day-title-wrap{flex:1;min-width:0}.day-title{color:var(--gray-800);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:700;line-height:1.3;display:block;overflow:hidden}.card-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.done-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:36px;min-height:36px;padding:4px;font-size:1.1rem;transition:transform .1s;display:flex}.done-btn:active{transform:scale(.85)}.expand-arrow{color:var(--gray-600);font-size:.65rem}.day-card-body{border-top:1px solid var(--gray-100);flex-direction:column;gap:14px;padding:0 14px 16px;animation:.2s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.detail-row{flex-wrap:wrap;gap:6px;padding-top:14px;display:flex}.detail-chip{border-radius:8px;align-items:center;gap:4px;padding:5px 10px;font-size:.72rem;font-weight:600;display:flex}.type-chip{background:var(--gray-100);color:var(--gray-600)}.detail-section{flex-direction:column;gap:8px;display:flex}.section-label{text-transform:uppercase;letter-spacing:.05em;color:var(--gray-600);font-size:.72rem;font-weight:700}.section-label-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.photo-direction{color:var(--gray-800);border-radius:var(--radius-sm);background:#fff9e6;border:1px solid #ffe99a;padding:10px 12px;font-size:.85rem;line-height:1.5}.caption-box{color:var(--gray-800);background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);white-space:pre-line;padding:12px 14px;font-size:.88rem;line-height:1.6}.hashtag-box{color:var(--purple);background:var(--purple-light);border-radius:var(--radius-sm);word-break:break-word;border:1px solid #c4aff7;padding:10px 12px;font-size:.82rem;font-weight:500;line-height:1.7}.tip-section{border-radius:var(--radius-sm);background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%);border:1px solid #86efac;padding:10px 12px}.tip-text{color:#166534;margin-top:4px;font-size:.82rem;line-height:1.5}.copy-btn{border:2px solid var(--purple);color:var(--purple);cursor:pointer;white-space:nowrap;background:#fff;border-radius:8px;flex-shrink:0;min-height:34px;padding:6px 12px;font-size:.72rem;font-weight:700;transition:all .2s}.copy-btn:active{transform:scale(.95)}.copy-btn.copied{color:#166534;background:#dcfce7;border-color:#86efac}.app-footer{background:var(--gray-800);color:#ffffffb3;margin-top:24px;padding:20px 16px}.footer-content{text-align:center;flex-direction:column;gap:8px;max-width:680px;margin:0 auto;display:flex}.footer-note{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:12px;font-size:.75rem;line-height:1.6}.footer-credit{color:#fff6;font-size:.7rem}@media (width>=640px){.app-header{padding:20px 24px 14px}.calendar-main{padding:24px}.day-card-header{padding:16px 18px}.day-card-body{padding:0 18px 20px}.app-title{font-size:1.75rem}.filter-tab{font-size:.8rem}}@media (width>=768px){.legend-panel{flex-direction:row;gap:24px}.pillar-legend{flex:1}}
