@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap");:root{--dashboard-bg:#f4f7fc;--dashboard-card:#fff;--dashboard-muted:#6b7280;--dashboard-accent:#3b82f6;--dashboard-primary:#3b82f6;--dashboard-primary-dark:#1d4ed8;--dashboard-primary-light:#eff6ff;--dashboard-glass:hsla(0,0%,100%,.75);--dashboard-border:rgba(0,0,0,.03);--dashboard-shadow-sm:0 1px 2px rgba(0,0,0,.02);--dashboard-shadow:0 4px 12px rgba(0,0,0,.02);--dashboard-shadow-lg:0 8px 24px rgba(0,0,0,.04)}.dashboard-grid-2col,.dashboard-grid-3col{font-family:Plus Jakarta Sans,sans-serif;color:#1a1d1f}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:0}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.dashboard-card{background:var(--dashboard-card);border-radius:0;box-shadow:var(--dashboard-shadow);border:1px solid var(--dashboard-border);transition:all .2s ease}.dashboard-card:hover{box-shadow:var(--dashboard-shadow-lg)}.stat-tile{position:relative;background:linear-gradient(180deg,#fff,#fbfdff);padding:14px 18px;border-radius:0;box-shadow:0 6px 18px rgba(2,6,23,.03);display:flex;flex-direction:column;justify-content:center;transition:all .2s ease}.stat-tile:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(2,6,23,.06)}.stat-tile .number{font-weight:800;font-size:24px;line-height:1;color:#0f172a}.stat-tile .label{font-size:13px;color:var(--dashboard-muted);margin-top:6px;font-weight:500}.stat-tile.highlight{border:1px solid rgba(59,130,246,.12);box-shadow:0 10px 30px rgba(59,130,246,.08);padding-left:24px;position:relative}.stat-tile.highlight:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:6px;border-radius:0;background:linear-gradient(180deg,#60a5fa,#3b82f6);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.22)}.school-logo{width:44px;height:44px;border-radius:0;background:linear-gradient(180deg,#eff6ff,#dbeafe);color:var(--dashboard-primary);justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.event-list-item,.school-logo{display:flex;align-items:center}.event-list-item{justify-content:space-between;padding:12px 0;border-bottom:1px dashed #f0f4f8}.event-list-item:last-child{border-bottom:none}.resource-list-item{padding:10px 0;border-bottom:1px dashed #f0f4f8;cursor:pointer;transition:all .2s ease}.resource-list-item:hover{padding-left:8px;color:var(--dashboard-primary)}.resource-list-item:last-child{border-bottom:none}.btn-dashboard-primary{background:#3b82f6;color:#fff;padding:8px 16px;border-radius:0;font-weight:700;font-size:14px;border:none;cursor:pointer;box-shadow:0 4px 12px rgba(59,130,246,.15);transition:all .2s ease}.btn-dashboard-primary:hover{background:#2563eb;box-shadow:0 6px 18px rgba(59,130,246,.25);transform:translateY(-1px)}.btn-dashboard-ghost{background:#fff;border:1px solid #dbeafe;color:var(--dashboard-primary);padding:8px 16px;border-radius:0;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-dashboard-ghost:hover{background:#eff6ff;border-color:#93c5fd}.btn-dashboard-outline{background:transparent;border:1px solid #dbeafe;color:var(--dashboard-primary);padding:8px 16px;border-radius:0;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-dashboard-outline:hover{background:#eff6ff;border-color:#93c5fd}.qr-wrapper{width:84px;height:84px;display:flex;align-items:center;justify-content:center;margin:12px auto 0}.membership-verified{color:#059669;font-weight:700;font-size:14px}.text-muted{color:#6b7280}.status-pill{padding:6px 12px;border-radius:0;font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:6px}.status-pill.approved{background:#e2f5e9;color:#1e7d46}.status-pill.pending{background:#fef3c7;color:#d97706}.status-pill.rejected{background:#fef2f2;color:#dc2626}.progress-bar-wrapper{width:100%;height:12px;background:#eff6ff;border-radius:0;overflow:hidden;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.6)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .5s ease;border-radius:0}.dashboard-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:8px 36px 8px 12px;border-radius:0;border:1px solid #e5e7eb;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%236b7280' d='M6 8L0 0h12z'/></svg>") no-repeat right 10px center;background-size:12px;box-shadow:var(--dashboard-shadow-sm);cursor:pointer;font-size:14px;font-weight:500}.dashboard-select:focus{outline:none;box-shadow:0 0 0 2px rgba(59,130,246,.3);border-color:var(--dashboard-primary)}.dashboard-search{padding:10px 16px;border-radius:0;background:#fff;border:1px solid #e5e7eb;width:100%;font-size:14px;transition:all .2s ease;box-shadow:var(--dashboard-shadow-sm)}.dashboard-search:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px rgba(59,130,246,.5)}.dashboard-search::-moz-placeholder{color:var(--dashboard-muted)}.dashboard-search::placeholder{color:var(--dashboard-muted)}.sidebar-nav-item{padding:12px 24px;border-radius:0;color:#6b7280;font-weight:500;font-size:14px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:16px;border-right:4px solid transparent}.sidebar-nav-item:hover{background:#eff6ff;color:#3b82f6}.sidebar-nav-item.active{background:#eff6ff;color:#1d4ed8;border-right-color:#3b82f6;font-weight:600}.dashboard-layout{display:flex;height:100vh;overflow:hidden;background-color:var(--dashboard-bg);font-family:Plus Jakarta Sans,sans-serif;color:#1a1d1f}.dashboard-left-sidebar{width:288px;min-width:288px;background:#fff;display:flex;flex-direction:column;border-right:1px solid #f3f4f6;height:100%;overflow-y:auto}.dashboard-main-content{flex:1;padding:32px;height:100%;overflow-y:auto}.dashboard-inner-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:24px}.dashboard-col-8{grid-column:span 8/span 8}.dashboard-col-4{grid-column:span 4/span 4}.dashboard-right-sidebar{display:flex;flex-direction:column;gap:24px}.dashboard-grid-2col,.dashboard-grid-3col{display:flex;height:100vh;overflow:hidden;background-color:var(--dashboard-bg);font-family:Plus Jakarta Sans,sans-serif;color:#1a1d1f}@media (max-width:1280px){.dashboard-left-sidebar{width:260px;min-width:260px}.dashboard-main-content{padding:24px}.dashboard-inner-grid{gap:16px}}@media (max-width:1024px){.dashboard-grid-2col,.dashboard-grid-3col,.dashboard-layout{flex-direction:column;height:auto}.dashboard-inner-grid{grid-template-columns:1fr;gap:12px}.dashboard-col-4,.dashboard-col-8{grid-column:span 1/span 1}.dashboard-grid-2col>.dashboard-left-sidebar,.dashboard-grid-3col>.dashboard-left-sidebar,.dashboard-layout>.dashboard-left-sidebar{display:none!important}.dashboard-right-sidebar{display:flex}.dashboard-card{padding:16px!important;border-radius:0}.dashboard-main-content{padding:12px!important;height:auto;overflow:visible}}@media (max-width:768px){.dashboard-grid-3col{gap:8px;padding:8px!important}.stat-tile{padding:10px 14px;border-radius:0}.stat-tile .number{font-size:18px}.stat-tile .label{font-size:11px;margin-top:4px}.stat-tile.highlight{padding-left:18px}.stat-tile.highlight:before{width:4px;top:6px;bottom:6px}.dashboard-card{padding:12px!important;border-radius:0;box-shadow:0 4px 12px rgba(15,23,42,.03)}.card-title{font-size:16px}.card-header{margin-bottom:12px}.school-logo{width:32px;height:32px;font-size:11px;border-radius:0}.event-list-item,.resource-list-item{padding:8px 0}.btn-dashboard-ghost,.btn-dashboard-outline,.btn-dashboard-primary{padding:6px 12px;font-size:13px;border-radius:0}.sidebar-nav-item{padding:8px 10px;border-radius:0;font-size:14px}.status-pill{padding:4px 10px;font-size:11px}.qr-wrapper{width:72px;height:72px}body{font-size:14px}.small-text,.text-muted{font-size:12px!important}.dashboard-search{padding:8px 12px;font-size:13px;border-radius:0}}@media (max-width:480px){.dashboard-grid-3col{gap:6px;padding:6px!important}.dashboard-card{padding:10px!important}.stat-tile{padding:8px 12px}.stat-tile .number{font-size:16px}.stat-tile .label{font-size:10px}.card-title{font-size:14px}.stat-grid-mobile{gap:6px!important}}.text-muted{color:#6b7280!important}.small-text{font-size:13px;color:#6b7280}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-title{font-size:18px;font-weight:700;color:#0f172a;margin:0}*{transition:background-color .2s ease,border-color .2s ease}@media (max-width:768px){.sidebar-nav-item,a,button,input[type=button],input[type=submit]{min-height:44px}}.btn-dashboard-ghost,.btn-dashboard-outline,.btn-dashboard-primary,.sidebar-nav-item,button{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-tap-highlight-color:transparent}@media (max-width:1024px){.dashboard-left-sidebar{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--dashboard-primary);outline-offset:2px}.word-of-day-card{position:relative;background:#eff6ff;border:1px solid #dbeafe;border-radius:0;padding:24px;box-shadow:0 1px 2px rgba(0,0,0,.05);overflow:hidden}@keyframes gradient-shift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.word-of-day-float{animation:gradient-shift 15s ease infinite,float-gentle 6s ease-in-out infinite}@keyframes float-gentle{0%,to{transform:translateY(0);box-shadow:0 20px 60px rgba(147,51,234,.15),0 8px 25px rgba(219,39,119,.1)}50%{transform:translateY(-8px);box-shadow:0 28px 70px rgba(147,51,234,.2),0 12px 30px rgba(219,39,119,.15)}}.word-of-day-decoration{position:absolute;border-radius:50%;background:hsla(0,0%,100%,.3);backdrop-filter:blur(10px);pointer-events:none}.word-of-day-decoration-1{width:80px;height:80px;top:-20px;right:-20px;animation:float-decoration 8s ease-in-out infinite}.word-of-day-decoration-2{width:50px;height:50px;bottom:30px;left:-15px;animation:float-decoration 10s ease-in-out infinite reverse}.word-of-day-decoration-3{width:30px;height:30px;top:40%;right:10%;animation:float-decoration 7s ease-in-out 2s infinite}@keyframes float-decoration{0%,to{transform:translate(0) scale(1);opacity:.4}50%{transform:translate(10px,-15px) scale(1.1);opacity:.6}}.word-of-day-inner{position:relative;z-index:1;text-align:center}.word-of-day-header{display:flex;flex-direction:column;align-items:center;margin-bottom:16px}.word-of-day-label{font-family:"Noto Serif JP",Hiragino Mincho ProN,Yu Mincho,serif;font-size:14px;font-weight:600;color:rgba(88,28,135,.9);letter-spacing:.15em;text-transform:uppercase}.word-of-day-label-en{font-size:10px;font-weight:500;color:rgba(88,28,135,.6);letter-spacing:.1em;margin-top:2px}.word-of-day-type-badge{display:inline-flex;align-items:center;padding:4px 12px;background:hsla(0,0%,100%,.7);backdrop-filter:blur(10px);border-radius:20px;font-family:Noto Sans JP,sans-serif;font-size:11px;font-weight:600;color:#6b21a8;box-shadow:0 2px 8px rgba(0,0,0,.05)}.word-of-day-difficulty-badge{text-transform:capitalize}.word-of-day-difficulty-badge,.word-of-day-featured-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:10px;font-weight:600}.word-of-day-featured-badge{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;box-shadow:0 2px 8px rgba(251,191,36,.3)}.word-of-day-headword{font-family:"Noto Serif JP",Hiragino Mincho ProN,Yu Mincho,serif;font-size:48px;font-weight:700;color:#1e1b4b;letter-spacing:.05em;line-height:1.2;margin:16px 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.1),0 4px 12px rgba(147,51,234,.15)}.word-of-day-reading{font-family:Noto Sans JP,sans-serif;font-size:16px;font-weight:400;color:rgba(88,28,135,.7);letter-spacing:.1em;margin-bottom:12px}.word-of-day-meaning{font-family:Noto Sans JP,Inter,sans-serif;font-size:16px;font-weight:500;color:#374151;line-height:1.6;max-width:300px;margin:0 auto 16px}.word-of-day-example-card{background:hsla(0,0%,100%,.6);backdrop-filter:blur(15px);border-radius:16px;padding:16px;margin:16px 0;box-shadow:0 4px 15px rgba(0,0,0,.05),inset 0 1px 0 hsla(0,0%,100%,.8);border:1px solid hsla(0,0%,100%,.5)}.word-of-day-example-label{font-size:10px;font-weight:600;color:rgba(88,28,135,.6);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}.word-of-day-example-text{font-family:"Noto Serif JP",serif;font-size:15px;font-weight:500;color:#1e1b4b;line-height:1.7;font-style:italic}.word-of-day-example-translation{font-family:Noto Sans JP,Inter,sans-serif;font-size:13px;font-weight:400;color:#6b7280;margin-top:8px;line-height:1.5}.word-of-day-notes{display:flex;align-items:flex-start;gap:8px;background:hsla(55,97%,88%,.7);backdrop-filter:blur(10px);border-radius:12px;padding:12px;margin-top:12px;font-size:12px;color:#713f12;line-height:1.5;text-align:left}.word-of-day-notes-icon{flex-shrink:0;font-size:14px}.word-of-day-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:12px}.word-of-day-tag{display:inline-block;padding:3px 10px;background:hsla(0,0%,100%,.5);border-radius:12px;font-size:11px;font-weight:500;color:#6b21a8}@media (max-width:640px){.word-of-day-card{padding:20px 16px;border-radius:20px}.word-of-day-headword{font-size:36px}.word-of-day-meaning,.word-of-day-reading{font-size:14px}.word-of-day-example-text{font-size:13px}.word-of-day-decoration-1{width:60px;height:60px}.word-of-day-decoration-2{width:35px;height:35px}.word-of-day-decoration-3{width:20px;height:20px}}@media (prefers-color-scheme:dark){.word-of-day-card{background:linear-gradient(135deg,rgba(252,231,243,.9),rgba(233,213,255,.9) 25%,rgba(199,210,254,.9) 50%,rgba(165,243,252,.9) 75%,hsla(81,88%,80%,.9))}}