:root {
    --bg-color: #FAFAFA;
    --bg-image: none;
    --black: #0D0D0D;
    --white: #FFFFFF;
    --grass-green:#D5FF70;
    --grass-green-50:#EAFFB7;
    --grass-green-50per: #D5FF7050;
    --grass-green-border:#B9F32C;
    --second-blue: #7FDDFF;
    --second-blue-20: #7FDDFF36;
    --second-blue-50: #7FDDFF80;
    --second-blue-50: #7FDDFF80;
    --second-blue-text: #0DB4F2;
    --second-blue-hover: #1D91BB;
    --warning: #EE0D27;
    --warning-10: #FFE5E8;
    --warning-20: #FFCCD2;
    --warning-40: #FF99A5;
    --caution: #F17400;
    --caution-10: #FFF1D7;
    --notice-20: #FFF1A6;
    --notice: #FFBB00;
    --donated-pink-text: #570522;
    --donated-pink-10: #FFEFF5;
    --gray-40: #F5F5F5;
    --gray-60: #EFEFEF;
    --gray-100: #E8E8E8;
    --gray-100-50per: #d1d1d180;
    --gray-150: #DFDFDF;
    --gray-400: #A6A6A6;
    --gray-450: #878787;
    --gray-500: #777777;
    --gray-600: #666666;
    --gray-700: #3F3F3F;
    --gray-800: #2A2A2A;
    --card-padding: 24px;
    --card-mobile-padding: 16px;
    --card-width: calc(100% - 48px);
    --card-mobile-width: calc(100% - 32px);
    --card-radius: 16px;
    --card-shadow: 0 1px 2px rgba(0,0,0,0.08),
                0 3px 6px rgba(0,0,0,0.08);
}

* {
    word-break: keep-all;
    border:0;
    padding:0;
    margin:0;
    border-spacing: 0;
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
    font-weight: 400;
    border-collapse: collapse;
}

p {
    line-height:150%;
    font-size: 16px;
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
    font-weight: 400;
}

html, body {
    margin:0 auto;
    padding:0;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: 16px;
    overflow-x: hidden !important;
    touch-action: pan-y;
    overscroll-behavior-x: none;
}

/* Custom desktop scrollbars; falls back gracefully elsewhere */
html, body {
    scrollbar-width: thin;
    scrollbar-color: var(--gray-450) transparent;
}

@supports selector(::-webkit-scrollbar) {
    html::-webkit-scrollbar,
    body::-webkit-scrollbar {
        width: 12px;
        height: 12px;
        background: transparent;
    }

    html::-webkit-scrollbar-track,
    body::-webkit-scrollbar-track {
        background: transparent;
    }

    html::-webkit-scrollbar-track:vertical,
    body::-webkit-scrollbar-track:vertical {
        background: linear-gradient(90deg, #f1f1f1, var(--gray-150));
    }

    html::-webkit-scrollbar-track:horizontal,
    body::-webkit-scrollbar-track:horizontal {
        background: linear-gradient(180deg, #d1d1d1 0%, var(--bg-color) 70%);
    }

    html::-webkit-scrollbar-thumb,
    body::-webkit-scrollbar-thumb {
        background-color: var(--gray-400);
        border-radius: 999px;
        border: 2px solid transparent;
        background-clip: padding-box;
        transition: background-color 0.2s ease;
    }

    html::-webkit-scrollbar-thumb:hover,
    body::-webkit-scrollbar-thumb:hover {
        background-color: var(--gray-500);
    }
}

h2 {
    font-weight: 600;
    font-size: 1.35rem;
    color: var(--black);
}

h3 {
    font-weight: 600;
    font-size: 1.25rem;
    color: var(--black);
}

.user-manager__content h3 {
    margin-bottom: 8px;
}

.user-manager__content .info h3 {
    margin-bottom: 0px;
}

strong, .accent {
    font-weight:700;
    color: var(--black);
    text-decoration: none;
}

.wrapper {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, #d5ff7080 0, #fafafa 160px);
}

.main-content {
    width:100%;
    flex: 1 0 auto;
    display: flex;
    flex-direction: column;
}

footer {
  margin-top: auto;
}

a {
    text-decoration: none;
    color:var(--second-blue-text);
}

a:hover, a:active {
    color:var(--second-blue-hover);
}


button:hover, button:active {
    cursor: pointer;
}

.hidden {
    display:none !important;
}

[hidden] { display: none !important; }

.hr-half {
    height:8px;
}
.hr {
    height:16px;
}

.button-primary {
    background-color: var(--grass-green);
    font-weight: 700;
    color: var(--black);
    border: 1px solid var(--grass-green-border);
    text-align: center;
    box-shadow: 0 1px 4px rgb(0 0 0 / 8%);
    white-space: nowrap;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
    display: flex;
    flex-direction: row;
    gap: 4px;
    align-items: center;
    justify-content: center;
}

.button-primary span {
    display: flex;
    flex-direction: row;
    gap: 4px;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}

.button-secondary {
    background-color: var(--white);
    border: 1px solid var(--gray-60);
    box-shadow: 0 1px 4px rgb(0 0 0 / 6%);
    text-align: center;
    color: var(--gray-700);
    font-weight: 700;
    white-space: nowrap;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
    display: flex;
    flex-direction: row;
    gap: 4px;
    align-items: center;
    justify-content: center;
}

.button-secondary:disabled, .button-primary:disabled {
    background-color: var(--gray-40);
    box-shadow: none;
    color: var(--gray-400);
    border: 1px solid var(--gray-100);
}

.button-primary:hover:disabled, .button-secondary:hover:disabled,
.button-primary:active:disabled, .button-secondary:active:disabled {
    color:var(--gray-400);
}

.button-secondary:disabled svg, .button-primary:disabled svg {
    fill:var(--gray-400);
}

.button-primary:hover, .button-secondary:hover,
.button-primary:active, .button-secondary:active {
    color:var(--black);
}

.button-danger {
  background: var(--warning-10);
  border: 1px solid var(--warning-20);
  color: var(--warning);
  box-shadow: 0 1px 4px rgb(0 0 0 / 8%);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
  font-weight: 700;
}

.button-add-shelf {
    border: 1px dashed var(--gray-400);
    border-radius: 12px;
    background: var(--gray-40);
    display:flex;
    gap: 4px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    color: var(--gray-800);
    padding: 12px 16px;
    font-weight: 700;
    font-size: 0.875rem;
}

.button-add-shelf:hover, .button-add-shelf:active {
    background: var(--gray-100);
}


.small {
    font-size: 0.8125rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 10px;
    border-radius: 8px;
}

.medium {
    font-size: 0.875rem;
    border-radius: 12px;
    padding: 12px 16px;
    width: fit-content;
}

.large {
    padding: 14px 16px;
    font-weight: 700;
    font-size: 16px;
    border-radius: 16px;
    width: 100%;
    gap: 6px;
}

.small:hover:not([disabled]), .meduum:hover:not([disabled]), .large:hover:not([disabled]) {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.08);
}

.small:active:not([disabled]), .medium:active:not([disabled]), .large:active:not([disabled]) {
  transform: translateY(0);
  box-shadow: none;
}

.small.is-hidden {
  display: none;
}

.small[disabled] {
  opacity: 0.6;
  cursor: wait;
}

.button-primary.large span {
    font-weight: 700;
    display: inline-flex;
    gap: 6px;
}

.htmx-indicator{display:none}
.htmx-request .htmx-indicator{display:inline}

.form-label {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--gray-800);
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.label-desc {
    font-size: 0.8125rem;
    color: var(--gray-500);
}

/* 검색창 아이콘 숨기기 iOS */

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
  display: none;
}

.search button {
    display:none;
}

input[type="search"] {
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box;
    width: 100%;
    max-width: 280px;
    background: var(--white) url(img/icon_search.svg) no-repeat left 10px center;
    padding: 12px 12px 12px 32px;
    border-radius: 12px;
    color: var(--black);
    font-size: 15px;
    box-shadow: 0px 1px 1px 0px rgb(0 0 0 / 8%),
                0px 0px 2px 0px rgb(0 0 0 / 8%);
}

input[type="search"]:focus {
    outline:2px solid var(--grass-green-border);
    background: var(--white) url(img/icon_search_focused.svg) no-repeat left 10px center;
}

select:focus, input[type="text"]:focus, textarea:focus,
input[type="number"]:focus, input[type="date"]:focus, input[type="time"]:focus, 
input[type="email"]:focus, input[type="password"]:focus, input[type="url"]:focus {
    outline:2px solid var(--grass-green-border);
    background-color: var(--white);
}

input[type="text"], input[type="number"], input[type="date"], input[type="time"], 
input[type="password"], input[type="email"],input[type="url"], 
select, textarea {
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 1rem;
  padding:12px;
  background-color: var(--white);
  color: var(--black);
  border-radius:8px;
}

input[type="text"]::placeholder, input[type="number"]::placeholder, input[type="date"]::placeholder, input[type="time"]::placeholder, 
input[type="search"]::placeholder, input[type="email"]::placeholder, [type="password"]::placeholder
textarea::placeholder {
    color:var(--gray-400);
}

input[type="text"]:disabled, input[type="number"]:disabled, input[type="date"]:disabled, 
input[type="time"]:disabled, input[type="password"]:disabled, input[type="email"]:disabled, input[type="url"]:disabled, 
select:disabled, textarea:disabled {
    background-color: var(--gray-40);
}

input:disabled::placeholder,
textarea:disabled::placeholder, select:disabled::placeholder {
    color: var(--gray-150);
}

select {
    padding: 12px 32px 12px 12px;
    background: var(--white) url(img/icon_select.svg) no-repeat right 10px center;
    -webkit-appearance: none !important;
    -moz-appearance: none;
    appearance: none;
}

blockquote,
.sun-editor .se-wrapper .se-wrapper-inner blockquote {
  position:relative;
  border-top:1px solid var(--second-blue);
  border-bottom:1px solid var(--second-blue);
  padding:16px 12px;
  color:var(--gray-600);
  margin: 24px 0;
  border-left: none !important;
  line-height: 1.5;
}

blockquote:before,
.sun-editor .se-wrapper .se-wrapper-inner blockquote:before {
  position:absolute;
  background-color:var(--white);
  pointer-events: none;
  content: url("img/img_blockquote_open.svg");
  line-height:1;
  text-align:center;
  top:-24px;
  left:-12px;
  padding:0px 8px;
  font-size:2rem;
  color:var(--second-blue);
}

blockquote:after,
.sun-editor .se-wrapper .se-wrapper-inner blockquote:after {
  position:absolute;
  right:-12px;
  bottom:-24px;
  background-color:var(--white);
  pointer-events: none;
  padding:8px;
  color:var(--second-blue);
  content: url("img/img_blockquote_close.svg");
  text-align:center;
  font-size: 2rem;
}

blockquote .quote-source {
    font-size: 0.875rem;
    color: var(--gray-800);
    font-weight: 600;
}

input[type="checkbox"]{
    -webkit-appearance: none !important;
    appearance: none;
    background-color: var(--white);
  }

input[type="checkbox"]::before {
    content: '';
    display: block;
    width: 16px;
    height: 16px;
    float:left;
    background: url(img/btn_checkbox_off.svg) center center no-repeat ;
    cursor: pointer;
  } 

input[type="checkbox"]:checked::before {
    background: url(img/btn_checkbox_on.svg) center center no-repeat;
    box-shadow: none;
  }
