@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
@layer theme{:root,:host{--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}}@layer base{*,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::-webkit-file-upload-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}::-webkit-file-upload-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:transparent;border-radius:0}:where(select:-webkit-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:-moz-any([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:-webkit-any([multiple],[size])) optgroup option:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:-moz-any([multiple],[size])) optgroup option:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:is([multiple],[size])) optgroup option:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))){padding-left:20px}:where(select:-webkit-any([multiple],[size])) optgroup option:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:where(select:-moz-any([multiple],[size])) optgroup option:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:where(select:is([multiple],[size])) optgroup option:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)){padding-right:20px}:not(:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::-webkit-file-upload-button{margin-right:4px}:not(:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::file-selector-button{margin-right:4px}:not(:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi)))::file-selector-button{margin-right:4px}:-webkit-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::-webkit-file-upload-button{margin-left:4px}:-moz-any(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::file-selector-button{margin-left:4px}:is(:lang(ae),:lang(ar),:lang(arc),:lang(bcc),:lang(bqi),:lang(ckb),:lang(dv),:lang(fa),:lang(glk),:lang(he),:lang(ku),:lang(mzn),:lang(nqo),:lang(pnb),:lang(ps),:lang(sd),:lang(ug),:lang(ur),:lang(yi))::file-selector-button{margin-left:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-year-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-month-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-day-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-hour-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-minute-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-second-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-millisecond-field{padding-top:0;padding-bottom:0}::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button{-webkit-appearance:button;-moz-appearance:button;appearance:button}input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-file-upload-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.contents{display:contents}.flex{display:flex}.h-screen{height:100vh}.items-center{align-items:center}.justify-center{justify-content:center}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}:root{--background:#fff;--foreground:#171717}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{background:var(--background);color:var(--foreground);font-family:Arial,Helvetica,sans-serif}:root{--primary-color:#9370db;--secondary-color:#e6e6fa;--hover-color:#d8bfd8;--accent-color:#6a5acd;--text-color-dark:#333;--text-color-light:#666;--border-color:#e0e0e0;--background-color-white:#fff;--background-color-gray:#f8f9fa;--star-color:#ffc107}body{background-color:var(--background-color-white);color:var(--text-color-dark);margin:0;font-family:Avenir Next,Hiragino Kaku Gothic ProN,Meiryo,sans-serif}a{color:inherit;text-decoration:none}*{box-sizing:border-box}.site-header{border-bottom:1px solid var(--border-color);z-index:100;background-color:silver;justify-content:space-between;align-items:center;height:64px;padding:10px 25px;display:flex;position:-webkit-sticky;position:sticky;top:0}.header-left{align-items:center;display:flex}.logo{color:var(--primary-color);margin-right:30px;font-size:32px;font-weight:800}.logo-link{align-items:center;height:100%;margin-right:30px;display:flex}.logo-link img{object-fit:contain;width:auto;height:80px}.main-nav ul{gap:25px;margin:0;padding:0;list-style:none;display:flex}.main-nav a{color:#555;border:1px solid transparent;border-radius:6px;padding:10px 15px;font-weight:700;transition:all .2s;display:block}.main-nav a:hover{background-color:#d8bfd8}.header-right{align-items:center;gap:15px;display:flex}.search-container{align-items:center;display:flex;position:relative}.search-input{border:1px solid #ccc;border-radius:20px;width:200px;padding:8px 35px 8px 15px;transition:all .3s}.search-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 5px rgba(147,112,219,.5)}.search-button{cursor:pointer;color:var(--text-color-light);background:0 0;border:none;padding:5px;position:absolute;top:50%;right:5px;transform:translateY(-50%)}.login-button{color:#fff;background-color:var(--primary-color);border-radius:20px;padding:8px 16px;font-weight:700;transition:background-color .3s}.login-button:hover{background-color:var(--accent-color)}.hamburger-button{cursor:pointer;z-index:10;background:0 0;border:none;flex-direction:column;justify-content:space-around;width:30px;height:24px;padding:0;display:none}.hamburger-line{background-color:var(--text-color-light);border-radius:5px;width:30px;height:3px}.sub-nav{background-color:var(--background-color-gray);z-index:5;opacity:0;pointer-events:none;width:40%;height:100vh;padding-top:80px;transition:right .3s ease-in-out;position:fixed;top:0;right:-100%;overflow-y:auto;box-shadow:-2px 0 5px rgba(0,0,0,.1)}.footer{color:#fff;background-color:#333;padding:50px 20px}.footer-content{justify-content:space-around;gap:40px;max-width:1200px;margin:0 auto;display:flex}.footer-logo-area,.footer-nav,.footer-contact{flex:1}.footer-logo{color:#9370db;margin-bottom:10px;font-size:24px;font-weight:700}.footer-copy{color:#aaa;margin:0;font-size:12px}.footer-heading{color:#eee;border-bottom:1px solid #555;margin-bottom:20px;padding-bottom:5px;font-size:18px;font-weight:700}.footer-list{margin:0;padding:0;list-style:none}.footer-list li{margin-bottom:10px}.footer-list a{color:#ccc;font-size:14px;transition:color .3s}.footer-list a:hover{color:#9370db}.contact-form-simple input,.contact-form-simple textarea{color:#fff;background-color:#444;border:1px solid #555;border-radius:5px;width:100%;margin-bottom:10px;padding:10px;font-size:14px}.contact-submit{background-color:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:5px;width:100%;padding:12px;font-weight:700;transition:background-color .3s}.contact-submit:hover{background-color:var(--accent-color)}.main{max-width:1200px;min-height:calc(100vh - 314px);margin:0 auto;padding:40px 20px}.page-title{text-align:center;border-bottom:3px solid var(--secondary-color);width:-moz-fit-content;width:fit-content;margin-bottom:40px;margin-left:auto;margin-right:auto;padding-bottom:10px;font-size:32px;font-weight:800;display:block}.content-wrapper{align-items:flex-start;gap:30px;display:flex}.sidebar{background-color:var(--background-color-gray);border-radius:10px;flex-shrink:0;width:280px;padding:20px}.filter-heading{color:var(--primary-color);margin-top:0;margin-bottom:25px;font-size:20px}.filter-group{margin-bottom:20px}.filter-group label{margin-bottom:5px;font-weight:700;display:block}.filter-select{border:1px solid #ccc;border-radius:5px;width:100%;padding:10px}.filter-apply-button{background-color:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:5px;width:100%;padding:10px;font-weight:700;transition:background-color .3s}.filter-apply-button:hover{background-color:var(--accent-color)}.main-list{flex-grow:1;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.no-results-message,.no-reviews-message{text-align:center;color:var(--text-color-light);padding:50px;font-size:18px}.class-card{border:1px solid var(--border-color);background-color:#fff;border-radius:10px;flex-direction:column;justify-content:space-between;padding:20px;transition:all .2s;display:flex;box-shadow:0 4px 12px rgba(0,0,0,.05)}.class-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.1)}.class-name{color:var(--primary-color);margin:0 0 8px;font-size:20px;font-weight:700}.class-info p{margin:5px 0;font-size:14px}.class-rating,.professor-rating,.item-rating{margin-top:10px;font-weight:700}.rating-star,.rating-star-large{color:var(--star-color)}.professor-card{border:1px solid var(--border-color);text-align:left;background-color:#fff;border-radius:10px;flex-direction:column;justify-content:space-between;align-items:stretch;height:100%;padding:20px;transition:all .2s;display:flex;box-shadow:0 4px 10px rgba(0,0,0,.05)}.professor-card:hover{transform:translateY(-5px);box-shadow:0 6px 15px rgba(0,0,0,.1)}.professor-name{font-size:22px;font-weight:700}.card-detail-button{text-align:center;background-color:var(--secondary-color);color:var(--primary-color);border-radius:5px;margin-top:auto;padding:8px;font-weight:700;transition:background-color .3s;display:block}.card-detail-button:hover{background-color:var(--hover-color)}.ranking-card{border-left:5px solid var(--secondary-color);background-color:#fff;border-radius:10px;align-items:center;padding:20px;transition:all .2s;display:flex;box-shadow:0 4px 10px rgba(0,0,0,.05)}.ranking-card:hover{transform:translateY(-3px);box-shadow:0 6px 16px rgba(0,0,0,.1)}.card-rank{color:var(--primary-color);text-align:center;width:60px;font-size:32px;font-weight:900}.ranking-card:first-child .card-rank{color:gold}.ranking-card:nth-child(2) .card-rank{color:silver}.ranking-card:nth-child(3) .card-rank{color:#cd7f32}.card-body{flex-grow:1}.item-title{font-size:18px;font-weight:700}.review-card{border:1px solid var(--border-color);background-color:#fff;border-radius:10px;margin-bottom:20px;padding:20px;transition:all .2s;box-shadow:0 4px 12px rgba(0,0,0,.05)}.review-meta{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;font-size:14px;display:flex}.review-content{line-height:1.6}.review-ratings{gap:30px;margin-top:15px;display:flex}.rating-value{color:var(--star-color);margin-left:8px;font-size:20px}.copy-container{text-align:center;padding:50px 0}.hero-title-area{place-content:center;gap:0;margin-bottom:10px;display:flex;position:relative}.copy-container h1{color:#333;margin:0;font-size:36px;font-weight:800;line-height:1.4;transform:translateY(35px)}.kyutan-image1{object-fit:contain;width:220px;height:auto;transform:translateY(-20px)}.contents{justify-content:center;gap:30px;margin-bottom:80px;display:flex}.contents-item{text-align:center;border-radius:15px;flex-direction:column;flex:1;align-items:center;padding:30px;transition:all .3s,box-shadow .3s;display:flex;box-shadow:0 6px 15px rgba(0,0,0,.08)}.contents-item:hover{transform:translateY(-8px);box-shadow:0 12px 20px rgba(0,0,0,.15)}.contents-icon{background-color:var(--secondary-color);stroke-width:2px;border-radius:50%;width:50px;height:50px;margin-bottom:15px}.usage-guide{background-color:var(--background-color-gray);border-radius:15px;padding:50px}.usage-guide .section-title{color:#333;border-bottom:3px solid #e6e6fa;align-items:center;margin-bottom:30px;padding-bottom:15px;font-size:28px;font-weight:700;display:flex}.usage-list{margin:0;padding:0;list-style:none}.usage-list li{margin-bottom:25px}.usage-list .step-title{color:#333;margin-bottom:5px;font-size:18px;font-weight:700}.usage-list .step-description{color:#666;padding-left:20px;font-size:16px;line-height:1.6}.rating-guide{border-top:1px solid #ddd;margin-top:2rem;padding-top:1rem}.rating-list{margin:1rem 0;padding-left:1.5rem;list-style:outside}.rating-list li{margin-bottom:.8rem;line-height:1.6}.kyutan-page{color:#333;background-color:#fff;border-radius:16px;max-width:800px;margin:0 auto;padding:3rem 1.5rem 4rem;line-height:1.8;box-shadow:0 4px 20px rgba(0,0,0,.05)}.kyutan-hero{text-align:center;margin-bottom:2.5rem}.kyutan-image{background:#f8f9fa;border-radius:50%;margin:0 auto;padding:1.5rem;transition:transform .3s;display:block;box-shadow:0 4px 12px rgba(147,112,219,.15)}.kyutan-image:hover{transform:scale(1.05)}.kyutan-catch{color:#9370db;margin-top:1rem;font-size:1.1rem;font-style:italic}.kyutan-section{border-bottom:1px solid #eee;margin-top:2.5rem;padding-bottom:1.5rem}.kyutan-section:last-of-type{border-bottom:none}.kyutan-section h2{color:#6a5acd;border-left:4px solid #9370db;margin-bottom:.8rem;padding-left:.6rem;font-size:1.4rem}.kyutan-profile{margin:0;padding:0;list-style:none}.kyutan-profile li{background-color:#f8f9fa;border-radius:6px;margin:.3rem 0;padding:.4rem .8rem;transition:background .2s}.kyutan-profile li:hover{background-color:#ede9f7}.kyutan-section p{color:#444;margin:.6rem 0}.kyutan-back{text-align:center;margin-top:3rem}.return-link{color:#6a5acd;font-weight:500;text-decoration:none;transition:color .2s}.return-link:hover{color:#9370db;text-decoration:underline}.info-text{text-align:center}.class-header-info{background-color:var(--background-color-gray);border-radius:12px;margin-bottom:40px;padding:30px}.class-title{margin-top:0;font-size:32px}.class-professor,.class-department{color:var(--text-color-light);font-size:18px}.class-professor:hover{color:var(--primary-color)}.section-heading{border-bottom:3px solid var(--secondary-color);justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:10px;display:flex}.post-review-button{background-color:var(--primary-color);color:#fff;border-radius:20px;padding:10px 20px;font-weight:700;transition:background-color .2s}.post-review-button:hover{background-color:var(--accent-color)}.professor-classes-list{border-top:1px dotted var(--border-color);margin-top:15px;padding-top:15px}.professor-classes-list h3{color:var(--text-color-light);margin:0 0 8px;font-size:16px}.professor-classes-list ul{margin:0;padding:0;list-style:none}.professor-classes-list li{margin-bottom:5px}.ranking-container{flex-grow:1;gap:30px;display:flex}.ranking-column{flex-direction:column;flex:1;gap:15px;display:flex}.ranking-column-title{text-align:center;border-bottom:2px solid var(--secondary-color);margin:0 0 10px;padding-bottom:10px;font-size:22px;font-weight:700}.ranking-column .ranking-list{flex-direction:column;gap:15px;display:flex}.form-container{border:1px solid var(--border-color);background-color:#fff;border-radius:10px;max-width:500px;margin:40px auto;padding:30px;box-shadow:0 4px 12px rgba(0,0,0,.05)}.form-main{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;display:flex}.form-group label{margin-bottom:5px;font-weight:700}.form-input{border:1px solid #ccc;border-radius:5px;padding:12px;font-size:16px}.form-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 5px rgba(147,112,219,.5)}.form-button{background-color:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:5px;padding:12px;font-size:16px;font-weight:700;transition:background-color .3s}.form-button:hover{background-color:var(--accent-color)}.form-footer{text-align:center;margin-top:20px}.form-link{color:var(--primary-color);font-weight:700}.mypage-container{max-width:900px;margin:0 auto;padding:2rem 1rem}.user-info{color:#555;margin-bottom:1.5rem;font-size:.95rem}.section-title{color:var(--text-color-dark);margin:1rem 0;font-size:1.3rem;font-weight:700}.settings-container{max-width:900px;margin:0 auto;padding:2rem 1rem}.settings-link-wrapper{justify-content:flex-end;margin-bottom:1rem;display:flex}.settings-button{background:var(--primary-color);color:#fff;border-radius:6px;padding:.5rem 1rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.settings-button:hover{background:#6a4c9c}.review-list{flex-direction:column;gap:1rem;display:flex}.review-item{border-bottom:1px solid #eee;padding-bottom:.8rem}.review-title{margin-bottom:.3rem;font-size:1.1rem}.review-title a{color:var(--text-color-light);font-weight:600;text-decoration:none}.review-title a:hover{color:var(--primary-color);text-decoration:underline}.review-actions{justify-content:flex-end;margin-top:.6rem;display:flex}.btn-delete{color:#fff;cursor:pointer;background:#e53e3e;border:none;border-radius:6px;padding:.4rem .9rem;font-size:.9rem;transition:background .2s}.btn-delete:hover{background:#c53030}.btn-delete:disabled{opacity:.6;cursor:not-allowed}.settings-section{border-top:1px solid var(--border-color);margin-top:40px;padding-top:20px}.settings-heading{margin-bottom:20px;font-size:20px}.settings-section small{color:var(--text-color-light);margin-top:5px;display:block}.divider{border:none;border-top:1px solid var(--border-color);margin:32px 0}.info-text{color:#555;margin-bottom:8px;font-size:.95rem}.form-button-secondary{color:#333;background-color:#f5f5f5;border:1px solid #ccc;border-radius:6px;padding:8px 16px;font-weight:500;transition:background-color .2s}.form-button-secondary:hover{background-color:#e9e9e9}.danger-zone{text-align:center;border-top:2px solid #e53e3e}.danger-zone p{color:var(--text-color-light)}.danger-button{color:#fff;cursor:pointer;background-color:#e53e3e;border:none;border-radius:5px;width:100%;margin-top:20px;padding:10px 15px;font-weight:700;transition:background-color .3s}.danger-button:hover{background-color:#c53030}.info-guide{background-color:var(--background-color-gray);border-left:5px solid var(--primary-color);border-radius:8px;margin-bottom:30px;padding:15px 20px}.info-guide p{margin:0;line-height:1.6}.info-list{margin-top:30px}.info-item{border-bottom:1px dashed var(--border-color);margin-bottom:30px;padding-bottom:20px}.info-item h2{margin:0 0 5px;font-size:20px}.info-date{color:var(--text-color-light);margin-bottom:10px;font-size:14px}.floating-post-button{z-index:1000;background-color:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 4px 12px rgba(0,0,0,.2)}.floating-post-button:hover{background-color:var(--accent-color);transform:scale(1.1)}.floating-post-button svg{width:28px;height:28px}.star-rating{display:flex}.star-rating .star{cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:32px;transition:color .2s}.star-rating .star.off{color:#ccc}.star-rating .star.on{color:var(--star-color)}.modal-overlay{z-index:2000;background-color:rgba(0,0,0,.6);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:10px;width:90%;max-width:500px;padding:25px;box-shadow:0 5px 15px rgba(0,0,0,.3)}.modal-title{margin:0 0 15px;font-size:22px}.modal-body p{margin:0 0 10px}.radio-group{margin-bottom:8px}.radio-group label{margin-left:8px}.modal-footer{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.modal-button-cancel,.modal-button-submit{cursor:pointer;border:1px solid #ccc;border-radius:5px;padding:8px 16px;font-weight:700}.modal-button-submit{background-color:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width:900px){.login-button,.main-nav{display:none}.hamburger-button{display:flex}.sub-nav{background-color:var(--background-color-gray);z-index:5;width:40%;height:100vh;padding-top:80px;transition:right .3s ease-in-out;position:fixed;top:0;right:-100%;overflow-y:auto;box-shadow:-2px 0 5px rgba(0,0,0,.1)}.sub-nav a{color:#555;border:1px solid transparent;border-radius:6px;padding:10px 15px;font-weight:700;transition:all .2s;display:block}.sub-nav a:hover{background-color:#d8bfd8}.sub-nav button{text-align:center;color:#555;border:1px solid transparent;border-radius:6px;width:100%;padding:10px 15px;font-weight:700;transition:all .2s;display:block}.sub-nav button:hover{background-color:#d8bfd8}.sub-nav.is-open{opacity:1;pointer-events:auto;right:0}.sub-nav ul{flex-direction:column;align-items:center;width:100%}.sub-nav li{text-align:center;border-bottom:1px solid var(--border-color);width:100%;padding:15px 0}.content-wrapper{flex-direction:column}.sidebar{width:100%}.sub-list{flex-direction:column;width:100%;display:flex}.kyutan-image{width:180px}.footer-content{text-align:center;flex-direction:column;align-items:center;gap:30px}.footer-logo-area,.footer-nav,.footer-contact{width:100%;max-width:400px}.footer-list{text-align:center}.footer-contact form{width:100%}}@media (max-width:600px){.hero-title-area{flex-direction:column;align-items:center;gap:8px}.kyutan-image{transform:translate(0)}.hero-title-area h1{transform:translateY(0)}}
